2016-04-13 03:58:47 -04:00
|
|
|
;;; notmuch-crypto.el --- functions for handling display of cryptographic metadata.
|
2011-05-25 18:01:19 -07:00
|
|
|
;;
|
|
|
|
;; Copyright © Jameson Rollins
|
|
|
|
;;
|
|
|
|
;; This file is part of Notmuch.
|
|
|
|
;;
|
|
|
|
;; Notmuch is free software: you can redistribute it and/or modify it
|
|
|
|
;; under the terms of the GNU General Public License as published by
|
|
|
|
;; the Free Software Foundation, either version 3 of the License, or
|
|
|
|
;; (at your option) any later version.
|
|
|
|
;;
|
|
|
|
;; Notmuch is distributed in the hope that it will be useful, but
|
|
|
|
;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
;; General Public License for more details.
|
|
|
|
;;
|
|
|
|
;; You should have received a copy of the GNU General Public License
|
2016-06-02 12:26:14 -04:00
|
|
|
;; along with Notmuch. If not, see <https://www.gnu.org/licenses/>.
|
2011-05-25 18:01:19 -07:00
|
|
|
;;
|
|
|
|
;; Authors: Jameson Rollins <jrollins@finestructure.net>
|
|
|
|
|
2016-04-13 03:58:47 -04:00
|
|
|
;;; Code:
|
|
|
|
|
2017-03-12 21:26:16 +02:00
|
|
|
(require 'epg)
|
2013-01-07 21:07:20 +00:00
|
|
|
(require 'notmuch-lib)
|
|
|
|
|
2017-07-12 07:48:18 -03:00
|
|
|
(defcustom notmuch-crypto-process-mime t
|
2011-05-25 18:01:19 -07:00
|
|
|
"Should cryptographic MIME parts be processed?
|
|
|
|
|
|
|
|
If this variable is non-nil signatures in multipart/signed
|
|
|
|
messages will be verified and multipart/encrypted parts will be
|
|
|
|
decrypted. The result of the crypto operation will be displayed
|
|
|
|
in a specially colored header button at the top of the processed
|
|
|
|
part. Signed parts will have variously colored headers depending
|
|
|
|
on the success or failure of the verification process and on the
|
|
|
|
validity of user ID of the signer.
|
|
|
|
|
|
|
|
The effect of setting this variable can be seen temporarily by
|
2011-05-31 10:06:00 -07:00
|
|
|
providing a prefix when viewing a signed or encrypted message, or
|
|
|
|
by providing a prefix when reloading the message in notmuch-show
|
|
|
|
mode."
|
2012-01-16 11:38:33 +01:00
|
|
|
:type 'boolean
|
2017-07-12 07:48:18 -03:00
|
|
|
:package-version '(notmuch . "0.25")
|
2012-01-16 11:38:33 +01:00
|
|
|
:group 'notmuch-crypto)
|
2011-05-25 18:01:19 -07:00
|
|
|
|
2011-12-13 18:32:10 +01:00
|
|
|
(defface notmuch-crypto-part-header
|
2016-10-28 15:31:42 -07:00
|
|
|
'((((class color)
|
|
|
|
(background dark))
|
|
|
|
(:foreground "LightBlue1"))
|
|
|
|
(((class color)
|
|
|
|
(background light))
|
|
|
|
(:foreground "blue")))
|
2011-12-13 18:32:10 +01:00
|
|
|
"Face used for crypto parts headers."
|
2012-01-16 11:38:33 +01:00
|
|
|
:group 'notmuch-crypto
|
|
|
|
:group 'notmuch-faces)
|
2011-12-13 18:32:10 +01:00
|
|
|
|
2011-03-31 00:31:04 +02:00
|
|
|
(defface notmuch-crypto-signature-good
|
|
|
|
'((t (:background "green" :foreground "black")))
|
|
|
|
"Face used for good signatures."
|
2012-01-16 11:38:33 +01:00
|
|
|
:group 'notmuch-crypto
|
|
|
|
:group 'notmuch-faces)
|
2011-03-31 00:31:04 +02:00
|
|
|
|
|
|
|
(defface notmuch-crypto-signature-good-key
|
|
|
|
'((t (:background "orange" :foreground "black")))
|
|
|
|
"Face used for good signatures."
|
2012-01-16 11:38:33 +01:00
|
|
|
:group 'notmuch-crypto
|
|
|
|
:group 'notmuch-faces)
|
2011-03-31 00:31:04 +02:00
|
|
|
|
|
|
|
(defface notmuch-crypto-signature-bad
|
|
|
|
'((t (:background "red" :foreground "black")))
|
|
|
|
"Face used for bad signatures."
|
2012-01-16 11:38:33 +01:00
|
|
|
:group 'notmuch-crypto
|
|
|
|
:group 'notmuch-faces)
|
2011-03-31 00:31:04 +02:00
|
|
|
|
|
|
|
(defface notmuch-crypto-signature-unknown
|
|
|
|
'((t (:background "red" :foreground "black")))
|
|
|
|
"Face used for signatures of unknown status."
|
2012-01-16 11:38:33 +01:00
|
|
|
:group 'notmuch-crypto
|
|
|
|
:group 'notmuch-faces)
|
2011-03-31 00:31:04 +02:00
|
|
|
|
|
|
|
(defface notmuch-crypto-decryption
|
|
|
|
'((t (:background "purple" :foreground "black")))
|
|
|
|
"Face used for encryption/decryption status messages."
|
2012-01-16 11:38:33 +01:00
|
|
|
:group 'notmuch-crypto
|
|
|
|
:group 'notmuch-faces)
|
2011-03-31 00:31:04 +02:00
|
|
|
|
2011-05-25 18:01:19 -07:00
|
|
|
(define-button-type 'notmuch-crypto-status-button-type
|
2011-12-17 10:47:48 -05:00
|
|
|
'action (lambda (button) (message (button-get button 'help-echo)))
|
2011-05-25 18:01:19 -07:00
|
|
|
'follow-link t
|
2013-01-07 21:07:20 +00:00
|
|
|
'help-echo "Set notmuch-crypto-process-mime to process cryptographic mime parts."
|
|
|
|
:supertype 'notmuch-button-type)
|
2011-05-25 18:01:19 -07:00
|
|
|
|
|
|
|
(defun notmuch-crypto-insert-sigstatus-button (sigstatus from)
|
|
|
|
(let* ((status (plist-get sigstatus :status))
|
|
|
|
(help-msg nil)
|
2019-04-22 13:18:14 -04:00
|
|
|
(show-button t)
|
|
|
|
(label nil)
|
2011-05-31 10:07:13 -07:00
|
|
|
(face 'notmuch-crypto-signature-unknown)
|
2011-12-17 10:47:48 -05:00
|
|
|
(button-action (lambda (button) (message (button-get button 'help-echo)))))
|
2011-05-25 18:01:19 -07:00
|
|
|
(cond
|
|
|
|
((string= status "good")
|
2011-05-31 10:07:13 -07:00
|
|
|
(let ((fingerprint (concat "0x" (plist-get sigstatus :fingerprint))))
|
|
|
|
;; if userid present, userid has full or greater validity
|
|
|
|
(if (plist-member sigstatus :userid)
|
|
|
|
(let ((userid (plist-get sigstatus :userid)))
|
|
|
|
(setq label (concat "Good signature by: " userid))
|
|
|
|
(setq face 'notmuch-crypto-signature-good))
|
|
|
|
(progn
|
|
|
|
(setq label (concat "Good signature by key: " fingerprint))
|
|
|
|
(setq face 'notmuch-crypto-signature-good-key)))
|
|
|
|
(setq button-action 'notmuch-crypto-sigstatus-good-callback)
|
|
|
|
(setq help-msg (concat "Click to list key ID 0x" fingerprint "."))))
|
2011-05-25 18:01:19 -07:00
|
|
|
((string= status "error")
|
|
|
|
(let ((keyid (concat "0x" (plist-get sigstatus :keyid))))
|
2011-05-31 10:07:13 -07:00
|
|
|
(setq label (concat "Unknown key ID " keyid " or unsupported algorithm"))
|
|
|
|
(setq button-action 'notmuch-crypto-sigstatus-error-callback)
|
2012-03-01 15:34:06 +02:00
|
|
|
(setq help-msg (concat "Click to retrieve key ID " keyid " from keyserver and redisplay."))))
|
2011-05-25 18:01:19 -07:00
|
|
|
((string= status "bad")
|
|
|
|
(let ((keyid (concat "0x" (plist-get sigstatus :keyid))))
|
|
|
|
(setq label (concat "Bad signature (claimed key ID " keyid ")"))
|
2011-03-31 00:31:04 +02:00
|
|
|
(setq face 'notmuch-crypto-signature-bad)))
|
2019-04-22 13:18:14 -04:00
|
|
|
(status
|
|
|
|
(setq label (concat "Unknown signature status: " status)))
|
2011-05-25 18:01:19 -07:00
|
|
|
(t
|
2019-04-22 13:18:14 -04:00
|
|
|
(setq show-button nil)))
|
|
|
|
(when show-button
|
|
|
|
(insert-button
|
|
|
|
(concat "[ " label " ]")
|
|
|
|
:type 'notmuch-crypto-status-button-type
|
|
|
|
'help-echo help-msg
|
|
|
|
'face face
|
|
|
|
'mouse-face face
|
|
|
|
'action button-action
|
|
|
|
:notmuch-sigstatus sigstatus
|
|
|
|
:notmuch-from from)
|
|
|
|
(insert "\n"))))
|
2011-05-25 18:01:19 -07:00
|
|
|
|
2012-02-21 10:42:32 -05:00
|
|
|
(declare-function notmuch-show-refresh-view "notmuch-show" (&optional reset-state))
|
2011-05-31 10:07:13 -07:00
|
|
|
|
|
|
|
(defun notmuch-crypto-sigstatus-good-callback (button)
|
|
|
|
(let* ((sigstatus (button-get button :notmuch-sigstatus))
|
|
|
|
(fingerprint (concat "0x" (plist-get sigstatus :fingerprint)))
|
|
|
|
(buffer (get-buffer-create "*notmuch-crypto-gpg-out*"))
|
|
|
|
(window (display-buffer buffer t nil)))
|
|
|
|
(with-selected-window window
|
|
|
|
(with-current-buffer buffer
|
2012-02-07 17:26:11 +00:00
|
|
|
(goto-char (point-max))
|
2019-02-09 12:34:37 -05:00
|
|
|
(call-process epg-gpg-program nil t t "--batch" "--no-tty" "--list-keys" fingerprint))
|
2011-05-31 10:07:13 -07:00
|
|
|
(recenter -1))))
|
|
|
|
|
|
|
|
(defun notmuch-crypto-sigstatus-error-callback (button)
|
|
|
|
(let* ((sigstatus (button-get button :notmuch-sigstatus))
|
|
|
|
(keyid (concat "0x" (plist-get sigstatus :keyid)))
|
|
|
|
(buffer (get-buffer-create "*notmuch-crypto-gpg-out*"))
|
|
|
|
(window (display-buffer buffer t nil)))
|
|
|
|
(with-selected-window window
|
|
|
|
(with-current-buffer buffer
|
2012-02-07 17:26:11 +00:00
|
|
|
(goto-char (point-max))
|
2019-02-09 12:34:37 -05:00
|
|
|
(call-process epg-gpg-program nil t t "--batch" "--no-tty" "--recv-keys" keyid)
|
2011-05-31 10:07:13 -07:00
|
|
|
(insert "\n")
|
2019-02-09 12:34:37 -05:00
|
|
|
(call-process epg-gpg-program nil t t "--batch" "--no-tty" "--list-keys" keyid))
|
2011-05-31 10:07:13 -07:00
|
|
|
(recenter -1))
|
2012-03-01 15:34:05 +02:00
|
|
|
(notmuch-show-refresh-view)))
|
2011-05-31 10:07:13 -07:00
|
|
|
|
2011-05-25 18:01:19 -07:00
|
|
|
(defun notmuch-crypto-insert-encstatus-button (encstatus)
|
|
|
|
(let* ((status (plist-get encstatus :status))
|
|
|
|
(help-msg nil)
|
2011-05-27 11:52:19 -07:00
|
|
|
(label "Decryption not attempted")
|
2011-03-31 00:31:04 +02:00
|
|
|
(face 'notmuch-crypto-decryption))
|
2011-05-25 18:01:19 -07:00
|
|
|
(cond
|
|
|
|
((string= status "good")
|
2011-05-27 11:52:19 -07:00
|
|
|
(setq label "Decryption successful"))
|
2011-05-25 18:01:19 -07:00
|
|
|
((string= status "bad")
|
2011-05-27 11:52:19 -07:00
|
|
|
(setq label "Decryption error"))
|
2011-05-25 18:01:19 -07:00
|
|
|
(t
|
2016-02-09 12:23:49 +00:00
|
|
|
(setq label (concat "Unknown encryption status"
|
|
|
|
(if status (concat ": " status))))))
|
2011-05-25 18:01:19 -07:00
|
|
|
(insert-button
|
2011-05-27 11:52:19 -07:00
|
|
|
(concat "[ " label " ]")
|
2011-05-25 18:01:19 -07:00
|
|
|
:type 'notmuch-crypto-status-button-type
|
|
|
|
'help-echo help-msg
|
|
|
|
'face face
|
|
|
|
'mouse-face face)
|
|
|
|
(insert "\n")))
|
|
|
|
|
|
|
|
;;
|
|
|
|
|
|
|
|
(provide 'notmuch-crypto)
|
2016-04-13 03:58:47 -04:00
|
|
|
|
|
|
|
;;; notmuch-crypto.el ends here
|