Mercurial > emacs
comparison lisp/gnus/pgg-pgp5.el @ 56927:55fd4f77387a after-merge-gnus-5_10
Revision: miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-523
Merge from emacs--gnus--5.10, gnus--rel--5.10
Patches applied:
* miles@gnu.org--gnu-2004/emacs--gnus--5.10--base-0
tag of miles@gnu.org--gnu-2004/emacs--cvs-trunk--0--patch-464
* miles@gnu.org--gnu-2004/emacs--gnus--5.10--patch-1
Import from CVS branch gnus-5_10-branch
* miles@gnu.org--gnu-2004/emacs--gnus--5.10--patch-2
Merge from lorentey@elte.hu--2004/emacs--multi-tty--0, emacs--cvs-trunk--0
* miles@gnu.org--gnu-2004/emacs--gnus--5.10--patch-3
Merge from gnus--rel--5.10
* miles@gnu.org--gnu-2004/emacs--gnus--5.10--patch-4
Merge from gnus--rel--5.10
* miles@gnu.org--gnu-2004/gnus--rel--5.10--patch-18
Update from CVS
* miles@gnu.org--gnu-2004/gnus--rel--5.10--patch-19
Remove autoconf-generated files from archive
* miles@gnu.org--gnu-2004/gnus--rel--5.10--patch-20
Update from CVS
author | Miles Bader <miles@gnu.org> |
---|---|
date | Sat, 04 Sep 2004 13:13:48 +0000 |
parents | |
children | 8ba7f19a10b9 |
comparison
equal
deleted
inserted
replaced
56926:f8e248e9a717 | 56927:55fd4f77387a |
---|---|
1 ;;; pgg-pgp5.el --- PGP 5.* support for PGG. | |
2 | |
3 ;; Copyright (C) 1999, 2000, 2003, 2004 Free Software Foundation, Inc. | |
4 | |
5 ;; Author: Daiki Ueno <ueno@unixuser.org> | |
6 ;; Created: 1999/11/02 | |
7 ;; Keywords: PGP, OpenPGP | |
8 | |
9 ;; This file is part of GNU Emacs. | |
10 | |
11 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
12 ;; it under the terms of the GNU General Public License as published by | |
13 ;; the Free Software Foundation; either version 2, or (at your option) | |
14 ;; any later version. | |
15 | |
16 ;; GNU Emacs is distributed in the hope that it will be useful, | |
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of | |
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
19 ;; GNU General Public License for more details. | |
20 | |
21 ;; You should have received a copy of the GNU General Public License | |
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the | |
23 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
24 ;; Boston, MA 02111-1307, USA. | |
25 | |
26 ;;; Code: | |
27 | |
28 (eval-when-compile | |
29 (require 'cl) ; for pgg macros | |
30 (require 'pgg)) | |
31 | |
32 (defgroup pgg-pgp5 () | |
33 "PGP 5.* interface" | |
34 :group 'pgg) | |
35 | |
36 (defcustom pgg-pgp5-pgpe-program "pgpe" | |
37 "PGP 5.* 'pgpe' executable." | |
38 :group 'pgg-pgp5 | |
39 :type 'string) | |
40 | |
41 (defcustom pgg-pgp5-pgps-program "pgps" | |
42 "PGP 5.* 'pgps' executable." | |
43 :group 'pgg-pgp5 | |
44 :type 'string) | |
45 | |
46 (defcustom pgg-pgp5-pgpk-program "pgpk" | |
47 "PGP 5.* 'pgpk' executable." | |
48 :group 'pgg-pgp5 | |
49 :type 'string) | |
50 | |
51 (defcustom pgg-pgp5-pgpv-program "pgpv" | |
52 "PGP 5.* 'pgpv' executable." | |
53 :group 'pgg-pgp5 | |
54 :type 'string) | |
55 | |
56 (defcustom pgg-pgp5-shell-file-name "/bin/sh" | |
57 "File name to load inferior shells from. | |
58 Bourne shell or its equivalent \(not tcsh) is needed for \"2>\"." | |
59 :group 'pgg-pgp5 | |
60 :type 'string) | |
61 | |
62 (defcustom pgg-pgp5-shell-command-switch "-c" | |
63 "Switch used to have the shell execute its command line argument." | |
64 :group 'pgg-pgp5 | |
65 :type 'string) | |
66 | |
67 (defcustom pgg-pgp5-extra-args nil | |
68 "Extra arguments for every PGP 5.* invocation." | |
69 :group 'pgg-pgp5 | |
70 :type '(choice | |
71 (const :tag "None" nil) | |
72 (string :tag "Arguments"))) | |
73 | |
74 (defvar pgg-pgp5-user-id nil | |
75 "PGP 5.* ID of your default identity.") | |
76 | |
77 (defun pgg-pgp5-process-region (start end passphrase program args) | |
78 (let* ((errors-file-name (pgg-make-temp-file "pgg-errors")) | |
79 (args | |
80 (append args | |
81 pgg-pgp5-extra-args | |
82 (list (concat "2>" errors-file-name)))) | |
83 (shell-file-name pgg-pgp5-shell-file-name) | |
84 (shell-command-switch pgg-pgp5-shell-command-switch) | |
85 (process-environment process-environment) | |
86 (output-buffer pgg-output-buffer) | |
87 (errors-buffer pgg-errors-buffer) | |
88 (process-connection-type nil) | |
89 process status exit-status) | |
90 (with-current-buffer (get-buffer-create output-buffer) | |
91 (buffer-disable-undo) | |
92 (erase-buffer)) | |
93 (when passphrase | |
94 (setenv "PGPPASSFD" "0")) | |
95 (unwind-protect | |
96 (progn | |
97 (let ((coding-system-for-read 'binary) | |
98 (coding-system-for-write 'binary)) | |
99 (setq process | |
100 (apply #'funcall | |
101 #'start-process-shell-command "*PGP*" output-buffer | |
102 program args))) | |
103 (set-process-sentinel process #'ignore) | |
104 (when passphrase | |
105 (process-send-string process (concat passphrase "\n"))) | |
106 (process-send-region process start end) | |
107 (process-send-eof process) | |
108 (while (eq 'run (process-status process)) | |
109 (accept-process-output process 5)) | |
110 (setq status (process-status process) | |
111 exit-status (process-exit-status process)) | |
112 (delete-process process) | |
113 (with-current-buffer output-buffer | |
114 (pgg-convert-lbt-region (point-min)(point-max) 'LF) | |
115 | |
116 (if (memq status '(stop signal)) | |
117 (error "%s exited abnormally: '%s'" program exit-status)) | |
118 (if (= 127 exit-status) | |
119 (error "%s could not be found" program)) | |
120 | |
121 (set-buffer (get-buffer-create errors-buffer)) | |
122 (buffer-disable-undo) | |
123 (erase-buffer) | |
124 (insert-file-contents errors-file-name))) | |
125 (if (and process (eq 'run (process-status process))) | |
126 (interrupt-process process)) | |
127 (condition-case nil | |
128 (delete-file errors-file-name) | |
129 (file-error nil))))) | |
130 | |
131 (defun pgg-pgp5-lookup-key (string &optional type) | |
132 "Search keys associated with STRING." | |
133 (let ((args (list "+language=en" "-l" string))) | |
134 (with-current-buffer (get-buffer-create pgg-output-buffer) | |
135 (buffer-disable-undo) | |
136 (erase-buffer) | |
137 (apply #'call-process pgg-pgp5-pgpk-program nil t nil args) | |
138 (goto-char (point-min)) | |
139 (when (re-search-forward "^sec" nil t) | |
140 (substring | |
141 (nth 2 (split-string | |
142 (buffer-substring (match-end 0)(progn (end-of-line)(point))))) | |
143 2))))) | |
144 | |
145 (defun pgg-pgp5-encrypt-region (start end recipients &optional sign) | |
146 "Encrypt the current region between START and END." | |
147 (let* ((pgg-pgp5-user-id (or pgg-pgp5-user-id pgg-default-user-id)) | |
148 (args | |
149 `("+NoBatchInvalidKeys=off" "-fat" "+batchmode=1" | |
150 ,@(if recipients | |
151 (apply #'append | |
152 (mapcar (lambda (rcpt) | |
153 (list "-r" | |
154 (concat "\"" rcpt "\""))) | |
155 (append recipients | |
156 (if pgg-encrypt-for-me | |
157 (list pgg-pgp5-user-id))))))))) | |
158 (pgg-pgp5-process-region start end nil pgg-pgp5-pgpe-program args) | |
159 (pgg-process-when-success nil))) | |
160 | |
161 (defun pgg-pgp5-decrypt-region (start end) | |
162 "Decrypt the current region between START and END." | |
163 (let* ((pgg-pgp5-user-id (or pgg-pgp5-user-id pgg-default-user-id)) | |
164 (passphrase | |
165 (pgg-read-passphrase | |
166 (format "PGP passphrase for %s: " pgg-pgp5-user-id) | |
167 (pgg-pgp5-lookup-key pgg-pgp5-user-id 'encrypt))) | |
168 (args | |
169 '("+verbose=1" "+batchmode=1" "+language=us" "-f"))) | |
170 (pgg-pgp5-process-region start end passphrase pgg-pgp5-pgpv-program args) | |
171 (pgg-process-when-success nil))) | |
172 | |
173 (defun pgg-pgp5-sign-region (start end &optional clearsign) | |
174 "Make detached signature from text between START and END." | |
175 (let* ((pgg-pgp5-user-id (or pgg-pgp5-user-id pgg-default-user-id)) | |
176 (passphrase | |
177 (pgg-read-passphrase | |
178 (format "PGP passphrase for %s: " pgg-pgp5-user-id) | |
179 (pgg-pgp5-lookup-key pgg-pgp5-user-id 'sign))) | |
180 (args | |
181 (list (if clearsign "-fat" "-fbat") | |
182 "+verbose=1" "+language=us" "+batchmode=1" | |
183 "-u" pgg-pgp5-user-id))) | |
184 (pgg-pgp5-process-region start end passphrase pgg-pgp5-pgps-program args) | |
185 (pgg-process-when-success | |
186 (when (re-search-forward "^-+BEGIN PGP SIGNATURE" nil t);XXX | |
187 (let ((packet | |
188 (cdr (assq 2 (pgg-parse-armor-region | |
189 (progn (beginning-of-line 2) | |
190 (point)) | |
191 (point-max)))))) | |
192 (if pgg-cache-passphrase | |
193 (pgg-add-passphrase-cache | |
194 (cdr (assq 'key-identifier packet)) | |
195 passphrase))))))) | |
196 | |
197 (defun pgg-pgp5-verify-region (start end &optional signature) | |
198 "Verify region between START and END as the detached signature SIGNATURE." | |
199 (let ((orig-file (pgg-make-temp-file "pgg")) | |
200 (args '("+verbose=1" "+batchmode=1" "+language=us")) | |
201 (orig-mode (default-file-modes))) | |
202 (unwind-protect | |
203 (progn | |
204 (set-default-file-modes 448) | |
205 (let ((coding-system-for-write 'binary) | |
206 jka-compr-compression-info-list jam-zcat-filename-list) | |
207 (write-region start end orig-file))) | |
208 (set-default-file-modes orig-mode)) | |
209 (when (stringp signature) | |
210 (copy-file signature (setq signature (concat orig-file ".asc"))) | |
211 (setq args (append args (list signature)))) | |
212 (pgg-pgp5-process-region (point)(point) nil pgg-pgp5-pgpv-program args) | |
213 (delete-file orig-file) | |
214 (if signature (delete-file signature)) | |
215 (with-current-buffer pgg-errors-buffer | |
216 (goto-char (point-min)) | |
217 (if (re-search-forward "^Good signature" nil t) | |
218 (progn | |
219 (set-buffer pgg-output-buffer) | |
220 (insert-buffer-substring pgg-errors-buffer) | |
221 t) | |
222 nil)))) | |
223 | |
224 (defun pgg-pgp5-insert-key () | |
225 "Insert public key at point." | |
226 (let* ((pgg-pgp5-user-id (or pgg-pgp5-user-id pgg-default-user-id)) | |
227 (args | |
228 (list "+verbose=1" "+batchmode=1" "+language=us" "-x" | |
229 (concat "\"" pgg-pgp5-user-id "\"")))) | |
230 (pgg-pgp5-process-region (point)(point) nil pgg-pgp5-pgpk-program args) | |
231 (insert-buffer-substring pgg-output-buffer))) | |
232 | |
233 (defun pgg-pgp5-snarf-keys-region (start end) | |
234 "Add all public keys in region between START and END to the keyring." | |
235 (let* ((pgg-pgp5-user-id (or pgg-pgp5-user-id pgg-default-user-id)) | |
236 (key-file (pgg-make-temp-file "pgg")) | |
237 (args | |
238 (list "+verbose=1" "+batchmode=1" "+language=us" "-a" | |
239 key-file))) | |
240 (let ((coding-system-for-write 'raw-text-dos)) | |
241 (write-region start end key-file)) | |
242 (pgg-pgp5-process-region start end nil pgg-pgp5-pgpk-program args) | |
243 (delete-file key-file) | |
244 (pgg-process-when-success nil))) | |
245 | |
246 (provide 'pgg-pgp5) | |
247 | |
248 ;;; arch-tag: 3dbd1073-6b3a-466c-9f55-5c587ffa6d7b | |
249 ;;; pgg-pgp5.el ends here |