]> git.eshelyaron.com Git - emacs.git/commitdiff
Protect against bad results from libravatar
authorLars Ingebrigtsen <larsi@gnus.org>
Thu, 28 Jan 2021 12:10:45 +0000 (13:10 +0100)
committerLars Ingebrigtsen <larsi@gnus.org>
Thu, 28 Jan 2021 12:10:45 +0000 (13:10 +0100)
* lisp/image/gravatar.el (gravatar--service-libravatar): Don't
have (gravatar-retrieve "foobar@zjp.codes" 'ignore) (which returns
a CNAME) bug out.

lisp/image/gravatar.el

index 4f37834a27f9d4f251199f30e831063eb99a9286..b1e2a314ce8024a25d847ac3ea29a0f56a52e8a7 100644 (file)
@@ -160,12 +160,16 @@ to track whether you're reading a specific mail."
                 (cond
                  ((and
                    result               ;there is a result
-                   (let* ((data (mapcar (lambda (record)
+                   (let* ((answers (dns-get 'answers result))
+                          (data (mapcar (lambda (record)
                                           (dns-get 'data (cdr record)))
-                                        (dns-get 'answers result)))
-                          (priorities (mapcar (lambda (r)
-                                                (dns-get 'priority r))
-                                              data))
+                                        ;; We may get junk data back (or CNAME;
+                                        ;; ignore).
+                                        (and (eq (dns-get 'type answers) 'SRV)
+                                             answers)))
+                          (priorities (and (mapcar (lambda (r)
+                                                     (dns-get 'priority r))
+                                                   data)))
                           (max-priority (if priorities
                                             (apply #'max priorities)
                                           0))