diff options
Diffstat (limited to 'lisp')
-rw-r--r-- | lisp/dns/default.nix | 15 | ||||
-rw-r--r-- | lisp/dns/resolver.lisp | 29 |
2 files changed, 44 insertions, 0 deletions
diff --git a/lisp/dns/default.nix b/lisp/dns/default.nix new file mode 100644 index 000000000000..c41b02f97ca8 --- /dev/null +++ b/lisp/dns/default.nix @@ -0,0 +1,15 @@ +{ pkgs, ... }: + +pkgs.nix.buildLisp.library { + name = "dns"; + + deps = with pkgs.third_party.lisp; [ + alexandria + cl-json + drakma + ]; + + srcs = [ + ./resolver.lisp + ]; +} diff --git a/lisp/dns/resolver.lisp b/lisp/dns/resolver.lisp new file mode 100644 index 000000000000..774be525cb20 --- /dev/null +++ b/lisp/dns/resolver.lisp @@ -0,0 +1,29 @@ +;; Initial implementation is a simple client for +;; https://developers.google.com/speed/public-dns/docs/doh/json + +(defpackage #:dns + (:documentation "Simple DNS resolver in Common Lisp") + (:use #:cl) + (:export #:lookup-txt #:lookup-mx)) + +(defvar *doh-base-url* "https://dns.google/resolve" + "Base URL of the service providing DNS-over-HTTP(S). Defaults to the + Google-hosted API.") + +(defun lookup-generic (name type) + (multiple-value-bind (body) + (drakma:http-request *doh-base-url* + :decode-content t + :want-stream t + :parameters `(("type" . ,type) + ("name" . ,name) + ("ct" . "application/x-javascript"))) + (cl-json:decode-json body))) + +(defun lookup-txt (name) + "Look up the TXT records at NAME." + (lookup-generic name "TXT")) + +(defun lookup-mx (name) + "Look up the MX records at NAME." + (lookup-generic name "MX")) |