diff options
author | Lars Ingebrigtsen <larsi@gnus.org> | 2019-08-23 04:49:52 +0200 |
---|---|---|
committer | Lars Ingebrigtsen <larsi@gnus.org> | 2019-08-23 04:49:52 +0200 |
commit | 53cb3d3e0ddb666dc5b7774957ca863c668213cb (patch) | |
tree | 011cf32acf25b0cd86debf5b3c22be289e60bd87 /lisp/net/net-utils.el | |
parent | b4d3a882a8423e81c418fc56b7a9677f5582fcc7 (diff) | |
parent | 29d485fb768fbe375d60fd80cb2dbdbd90f3becc (diff) | |
download | emacs-53cb3d3e0ddb666dc5b7774957ca863c668213cb.tar.gz emacs-53cb3d3e0ddb666dc5b7774957ca863c668213cb.tar.bz2 emacs-53cb3d3e0ddb666dc5b7774957ca863c668213cb.zip |
Merge remote-tracking branch 'origin/netsec'
Diffstat (limited to 'lisp/net/net-utils.el')
-rw-r--r-- | lisp/net/net-utils.el | 75 |
1 files changed, 74 insertions, 1 deletions
diff --git a/lisp/net/net-utils.el b/lisp/net/net-utils.el index dcc7e01b6b4..4f68e5db61d 100644 --- a/lisp/net/net-utils.el +++ b/lisp/net/net-utils.el @@ -43,6 +43,10 @@ ;; still use them for queries). Actually the trend these ;; days is for /sbin to be a symlink to /usr/sbin, but we still need to ;; search both for older systems. + +(require 'subr-x) +(require 'cl-lib) + (defun net-utils--executable-find-sbin (command) "Return absolute name of COMMAND if found in an sbin directory." (let ((exec-path '("/sbin" "/usr/sbin" "/usr/local/sbin"))) @@ -514,7 +518,11 @@ Optional argument NAME-SERVER says which server to use for DNS resolution. Interactively, prompt for NAME-SERVER if invoked with prefix argument. -This command uses `nslookup-program' for looking up the DNS information." +This command uses `nslookup-program' for looking up the DNS information. + +See also: `nslookup-host-ipv4', `nslookup-host-ipv6' for +non-interactive versions of this function more suitable for use +in Lisp code." (interactive (list (read-from-minibuffer "Lookup host: " (net-utils-machine-at-point)) (if current-prefix-arg (read-from-minibuffer "Name server: ")))) @@ -531,6 +539,71 @@ This command uses `nslookup-program' for looking up the DNS information." options))) ;;;###autoload +(defun nslookup-host-ipv4 (host &optional name-server format) + "Return the IPv4 address for HOST (name or IP address). +Optional argument NAME-SERVER says which server to use for DNS +resolution. + +If FORMAT is `string', returns the IP address as a +string (default). If FORMAT is `vector', returns a 4-integer +vector of octets. + +This command uses `nslookup-program' to look up DNS records." + (let* ((args `(,nslookup-program "-type=A" ,host ,name-server)) + (output (shell-command-to-string + (string-join (cl-remove nil args) " "))) + (ip (or (and (string-match + "Name:.*\nAddress: *\\(\\([0-9]\\{1,3\\}\\.?\\)\\{4\\}\\)" + output) + (match-string 1 output)) + host))) + (cond ((memq format '(string nil)) + ip) + ((eq format 'vector) + (apply #'vector (mapcar #'string-to-number (split-string ip "\\.")))) + (t (error "Invalid format: %s" format))))) + +(defun ipv6-expand (ipv6-vector) + (let ((len (length ipv6-vector))) + (if (< len 8) + (let* ((pivot (cl-position 0 ipv6-vector)) + (head (cl-subseq ipv6-vector 0 pivot)) + (tail (cl-subseq ipv6-vector (1+ pivot) len))) + (vconcat head (make-vector (- 8 (1- len)) 0) tail)) + ipv6-vector))) + +;;;###autoload +(defun nslookup-host-ipv6 (host &optional name-server format) + "Return the IPv6 address for HOST (name or IP address). +Optional argument NAME-SERVER says which server to use for DNS +resolution. + +If FORMAT is `string', returns the IP address as a +string (default). If FORMAT is `vector', returns a 8-integer +vector of hextets. + +This command uses `nslookup-program' to look up DNS records." + (let* ((args `(,nslookup-program "-type=AAAA" ,host ,name-server)) + (output (shell-command-to-string + (string-join (cl-remove nil args) " "))) + (hextet "[0-9a-fA-F]\\{1,4\\}") + (ip-regex (concat "\\(\\(" hextet "[:]\\)\\{1,6\\}\\([:]?\\(" hextet "\\)\\{1,6\\}\\)\\)")) + (ip (or (and (string-match + (if (eq system-type 'windows-nt) + (concat "Name:.*\nAddress: *" ip-regex) + (concat "has AAAA address " ip-regex)) + output) + (match-string 1 output)) + host))) + (cond ((memq format '(string nil)) + ip) + ((eq format 'vector) + (ipv6-expand (apply #'vector + (cl-loop for hextet in (split-string ip "[:]") + collect (string-to-number hextet 16))))) + (t (error "Invalid format: %s" format))))) + +;;;###autoload (defun nslookup () "Run `nslookup-program'." (interactive) |