$(dir)/notmuch-address.el \
$(dir)/notmuch-maildir-fcc.el \
$(dir)/notmuch-message.el \
+ $(dir)/notmuch-crypto.el \
$(dir)/coolj.el
emacs_images := \
--- /dev/null
+;; notmuch-crypto.el --- functions for handling display of cryptographic metadata.
+;;
+;; 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
+;; along with Notmuch. If not, see <http://www.gnu.org/licenses/>.
+;;
+;; Authors: Jameson Rollins <jrollins@finestructure.net>
+
+(defcustom notmuch-crypto-process-mime nil
+ "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
+viewing a signed or encrypted message with M-RET in notmuch
+search."
+ :group 'notmuch
+ :type 'boolean)
+
+(define-button-type 'notmuch-crypto-status-button-type
+ 'action '(lambda (button) (message (button-get button 'help-echo)))
+ 'follow-link t
+ 'help-echo "Set notmuch-crypto-process-mime to process cryptographic mime parts."
+ 'face '(:foreground "blue")
+ 'mouse-face '(:foreground "blue"))
+
+(defun notmuch-crypto-insert-sigstatus-button (sigstatus from)
+ (let* ((status (plist-get sigstatus :status))
+ (help-msg nil)
+ (label "multipart/signed: signature not processed")
+ (face '(:background "red" :foreground "black")))
+ (cond
+ ((string= status "good")
+ ; 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 '(:background "green" :foreground "black")))
+ (let ((fingerprint (concat "0x" (plist-get sigstatus :fingerprint))))
+ (setq label (concat "Good signature by key: " fingerprint))
+ (setq face '(:background "orange" :foreground "black")))))
+ ((string= status "error")
+ (let ((keyid (concat "0x" (plist-get sigstatus :keyid))))
+ (setq label (concat "Unknown key ID " keyid " or unsupported algorithm"))
+ (setq face '(:background "red" :foreground "black"))))
+ ((string= status "bad")
+ (let ((keyid (concat "0x" (plist-get sigstatus :keyid))))
+ (setq label (concat "Bad signature (claimed key ID " keyid ")"))
+ (setq face '(:background "red" :foreground "black"))))
+ (t
+ (setq label "Unknown signature status")
+ (if status (setq label (concat label " \"" status "\"")))))
+ (insert-button
+ (concat "[ " label " ]")
+ :type 'notmuch-crypto-status-button-type
+ 'help-echo help-msg
+ 'face face
+ 'mouse-face face
+ :notmuch-sigstatus sigstatus
+ :notmuch-from from)
+ (insert "\n")))
+
+;;
+
+(provide 'notmuch-crypto)
'(("inbox" . "tag:inbox")
("unread" . "tag:unread")))))
-(defcustom notmuch-crypto-process-mime nil
- "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
-viewing a signed or encrypted message with M-RET in notmuch
-search."
- :group 'notmuch
- :type 'boolean)
-
(defun notmuch-version ()
"Return a string with the notmuch version number."
(let ((long-string
(require 'notmuch-query)
(require 'notmuch-wash)
(require 'notmuch-mua)
+(require 'notmuch-crypto)
(declare-function notmuch-call-notmuch-process "notmuch" (&rest args))
(declare-function notmuch-fontify-headers "notmuch" nil)
(indent-rigidly start (point) 1)))
t)
-(define-button-type 'notmuch-show-sigstatus-button-type
- 'action '(lambda (button) (message (button-get button 'help-echo)))
- 'follow-link t
- 'help-echo "Set notmuch-crypto-process-mime for automatic signature verification."
- 'face '(:foreground "blue")
- 'mouse-face '(:foreground "blue"))
-
-(defun notmuch-show-insert-sigstatus-header (sigstatus from)
- (let* ((status (plist-get sigstatus :status))
- (help-msg nil)
- (label "multipart/signed: signature not processed")
- (face '(:background "red" :foreground "black")))
- (cond
- ((string= status "good")
- ; 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 '(:background "green" :foreground "black")))
- (let ((fingerprint (concat "0x" (plist-get sigstatus :fingerprint))))
- (setq label (concat "Good signature by key: " fingerprint))
- (setq face '(:background "orange" :foreground "black")))))
- ((string= status "error")
- (let ((keyid (concat "0x" (plist-get sigstatus :keyid))))
- (setq label (concat "Unknown key ID " keyid " or unsupported algorithm"))
- (setq face '(:background "red" :foreground "black"))))
- ((string= status "bad")
- (let ((keyid (concat "0x" (plist-get sigstatus :keyid))))
- (setq label (concat "Bad signature (claimed key ID " keyid ")"))
- (setq face '(:background "red" :foreground "black"))))
- (t
- (setq label "Unknown signature status")
- (if status (setq label (concat label " \"" status "\"")))))
- (insert-button
- (concat "[ " label " ]")
- :type 'notmuch-show-sigstatus-button-type
- 'help-echo help-msg
- 'face face
- 'mouse-face face
- :notmuch-sigstatus sigstatus
- :notmuch-from from)
- (insert "\n")))
-
(defun notmuch-show-insert-part-multipart/signed (msg part content-type nth depth declared-type)
(if (plist-member part :sigstatus)
(let* ((headers (plist-get msg :headers))
(from (plist-get headers :From))
(sigstatus (car (plist-get part :sigstatus))))
- (notmuch-show-insert-sigstatus-header sigstatus from))
+ (notmuch-crypto-insert-sigstatus-button sigstatus from))
(insert-button "[ multipart/signed ]\n"
- :type 'notmuch-show-sigstatus-button-type))
+ :type 'notmuch-crypto-status-button-type))
(let ((inner-parts (plist-get part :content))
(start (point)))
(from (plist-get headers :From))
(sigstatus (car (plist-get part :sigstatus))))
(if (plist-member sigstatus :status)
- (notmuch-show-insert-sigstatus-header sigstatus from))))
+ (notmuch-crypto-insert-sigstatus-button sigstatus from))))
(let ((inner-parts (plist-get part :content))
(start (point)))