plstore.el (plstore--decrypt): Clear entry in `plstore-passphrase-alist' if decryptio...
authorDaiki Ueno <ueno@gnu.org>
Tue, 31 Mar 2015 12:42:30 +0000 (12:42 +0000)
committerKatsumi Yamaoka <yamaoka@jpl.org>
Tue, 31 Mar 2015 12:42:30 +0000 (12:42 +0000)
lisp/ChangeLog
lisp/plstore.el

index 36a35fd..77573c6 100644 (file)
@@ -1,3 +1,8 @@
+2015-03-31  Daiki Ueno  <ueno@gnu.org>
+
+       * plstore.el (plstore--decrypt): Clear entry in
+       `plstore-passphrase-alist' if decryption failed (bug#20030).
+
 2015-03-28  Adam Sjøgren  <asjo@koldfront.dk>
 
        * gnus-sum.el (gnus-summary-make-menu-bar): Add "Display HTML images"
index 12a0413..175e272 100644 (file)
@@ -270,9 +270,16 @@ symmetric encryption will be used.")
         context
         (cons #'plstore-progress-callback-function
               (format "Decrypting %s" (plstore-get-file plstore))))
-       (setq plain
-             (epg-decrypt-string context
-                                 (plstore--get-encrypted-data plstore)))
+       (condition-case error
+           (setq plain
+                 (epg-decrypt-string context
+                                     (plstore--get-encrypted-data plstore)))
+         (error
+          (let ((entry (assoc (plstore-get-file plstore)
+                              plstore-passphrase-alist)))
+            (if entry
+                (setcdr entry nil)))
+          (signal (car error) (cdr error))))
        (plstore--set-secret-alist plstore (car (read-from-string plain)))
        (plstore--merge-secret plstore)
        (plstore--set-encrypted-data plstore nil))))