summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Albinus <michael.albinus@gmx.de>2022-08-22 16:56:57 +0200
committerMichael Albinus <michael.albinus@gmx.de>2022-08-22 16:56:57 +0200
commitf579cd472cbf3d9af52c87b65473b56ce918abba (patch)
treec473db135f3a41f0005f137db6c1d2a49da0b631
parent6c9696e3de171d84c4241d95872b83977cd44593 (diff)
downloademacs-f579cd472cbf3d9af52c87b65473b56ce918abba.tar.gz
auth-source: Fix wrong-type-argument when searching secret services
`auth-source-search' can be called with an integer port number, while the backend implementation doesn't allow non-string attributes. * doc/misc/auth.texi (Secret Service API): Attribute values are stringified. * lisp/auth-source.el (auth-source-secrets-search): Ensure attributes are string. (Bug#55199)
-rw-r--r--doc/misc/auth.texi6
-rw-r--r--lisp/auth-source.el11
2 files changed, 12 insertions, 5 deletions
diff --git a/doc/misc/auth.texi b/doc/misc/auth.texi
index 91a9afd9c9f..9dc63af6bcc 100644
--- a/doc/misc/auth.texi
+++ b/doc/misc/auth.texi
@@ -384,7 +384,7 @@ This function creates a new item in @var{collection} with label
@var{item} and password @var{password}. The label @var{item} does not
have to be unique in @var{collection}. @var{attributes} are key-value
pairs set for the created item. The keys are keyword symbols,
-starting with a colon. Example:
+starting with a colon; values are strings. Example:
@example
;;; The collection is "session", the label is "my item"
@@ -466,6 +466,10 @@ then fall back to @file{~/.authinfo.gpg}.
"~/.authinfo.gpg"))
@end example
+Attribute values in the auth-source spec, which are not strings (like
+port numbers), are stringified prior calling the @file{secrets.el}
+functions.
+
@node The Unix password store
@chapter The Unix password store
diff --git a/lisp/auth-source.el b/lisp/auth-source.el
index f198362f106..c79e5b81f76 100644
--- a/lisp/auth-source.el
+++ b/lisp/auth-source.el
@@ -1618,10 +1618,13 @@ authentication tokens:
(search-specs (auth-source-secrets-listify-pattern
(apply #'append (mapcar
(lambda (k)
- (if (or (null (plist-get spec k))
- (eq t (plist-get spec k)))
- nil
- (list k (plist-get spec k))))
+ (let ((v (plist-get spec k)))
+ (if (or (null v)
+ (eq t v))
+ nil
+ (list
+ k
+ (auth-source-ensure-strings v)))))
search-keys))))
;; needed keys (always including host, login, port, and secret)
(returned-keys (delete-dups (append