* epa.el (epa-decrypt-file): Display verify result if the message
[elisp/epg.git] / ChangeLog
1 2006-05-25  Daiki Ueno  <ueno@unixuser.org>
2
3         * epa.el (epa-decrypt-file): Display verify result if the message
4         is signed.
5         (epa-decrypt-region): New command.
6
7 2006-05-11  Daiki Ueno  <ueno@unixuser.org>
8
9         * epa.el (epa-armor): New user option.
10         (epa-textmode): New user option.
11
12 2006-05-02  Daiki Ueno  <ueno@unixuser.org>
13
14         * epg.el (epg-make-key-signature): New object epg-key-signature.
15         (epg-list-keys): Collect key signatures.
16         (epg-make-sub-key): Renamed secret -> secret-p.
17         (epg-list-keys-postprocess-one-key): Abolished.
18         (epg-list-keys): Reverse all keys, sub-keys, user-ids, and key
19         signatures by itself.
20         (epg-no-data-reason-alist): New constant.
21         (epg-unexpected-reason-alist): New constant.
22
23 2006-05-01  Daiki Ueno  <ueno@unixuser.org>
24
25         * epg.el (epg-invalid-recipients-reason-alist): Renamed.
26         (epg-delete-problem-reason-alist): Renamed.
27         (epg-import-ok-reason-alist): New constant.
28         (epg-import-problem-reason-alist): New constant.
29         (epg-status-IMPORTED): New function.
30         (epg-status-IMPORT_OK): New function.
31         (epg-status-IMPORT_PROBLEM): New function.
32         (epg-start-import-keys): Don't use a temporary output file.
33         (epg-start-receive-keys): New function.
34         (epg-import-keys-from-server): New function.
35         (epg-receive-keys): Alias to epg-import-keys-from-server.
36
37 2006-05-01  Daiki Ueno  <ueno@unixuser.org>
38
39         * epg.el (epg-start): Signal an error if the process of CONTEXT is
40         already running for other operations.
41         (epg-flush): Abolished.
42         (epg-start-generate-key): New function.
43         (epg-generate-key-from-file): New function.
44         (epg-generate-key-from-string): New function.
45         (epg-status-KEY_CREATED): New function.
46         (epg-status-KEY_NOT_CREATED): New function.
47         (epg-new-signature-type-alist): New variable.
48         (epg-make-new-signature): New object epg-new-signature.
49         (epg-status-SIG_CREATED): Set epg-new-signature object.
50         (epg-new-signature-to-string): New function.
51         (epg-make-signature): Added slots for signature class and version.
52         (epg-start-sign): Fixed rule of the MODE argument.
53
54 2006-04-30  Daiki Ueno  <ueno@unixuser.org>
55
56         * epa.el (epa-delete-keys): Support deletion of secret keys.
57
58         * pgg-epg.el (pgg-epg-decrypt-region): Convert line endings of the
59         decrypted text.
60
61         * epg.el (epg-read-output): Don't convert line endings of the
62         output file.
63         (epg-cancel): Set 'error result.
64
65 2006-04-29  Daiki Ueno  <ueno@unixuser.org>
66
67         * epg.el (epg-make-signature): Removed user-id; added
68         creation-time, expiration-time, pubkey-algorithm,
69         digest-algorithm.
70         (epg-process-sentinel): Abolished.
71         (epg-signature-to-string): Decode DN.
72         (epg-list-keys): Cache user-id in epg-user-id-alist.
73         (epg-make-user-id): Renamed name -> string.
74
75 2006-04-29  Daiki Ueno  <ueno@unixuser.org>
76
77         * epg.el (epg-status-ERRSIG): New function.
78         (epg-verify-file): Signal an error if we encounter ERRSIG status.
79         (epg-verify-string): Ditto.
80
81 2006-04-28  Daiki Ueno  <ueno@unixuser.org>
82
83         * epg.el: Added typecheck to accessors to objects.
84
85 2006-04-26  Daiki Ueno  <ueno@unixuser.org>
86
87         * epg.el (epg-status-GET_HIDDEN): Pass epg-context as the first
88         argument of passphrase-callback.
89         (epg-status-PROGRESS): Ditto.
90
91 2006-04-26  Daiki Ueno  <ueno@unixuser.org>
92
93         * epa.el (epa-select-keys): Don't set inhibit-quit when
94         recursive-edit is called.
95         (epg-cancel): New function.
96
97 2006-04-25  Daiki Ueno  <ueno@unixuser.org>
98
99         * epg.el (epg-process-sentinel): New function; set 'error if gpg
100         process exited abnormally, but we have not received an error
101         response from it.
102         (epg-sign-file): Signal an error only when a signature is not
103         created.
104         (epg-sign-string): Ditto.
105         (epg-encrypt-file): Signal an error if SIGN is specified and
106         signature is not created.
107         (epg-encrypt-string): Ditto.
108
109 2006-04-22  Daiki Ueno  <ueno@unixuser.org>
110
111         * epa.el (epa-key-widget-value-create): Decode DN.
112         (epa-list-keys): Add the PROTOCOL argument.
113         (epa-select-keys): Require CONTEXT as the first argument.
114
115         * epg.el (epg-gpgsm-program): New user option.
116         (epg-dn-type-alist): New variable.
117         (epg-start): Don't specify --command-fd if protocol is CMS.
118         (epg-list-keys): Require CONTEXT as the first argument.
119         (epg-dn-from-string): New function.
120         (epg-decode-dn): New function.
121
122 2006-04-21  Daiki Ueno  <ueno@unixuser.org>
123
124         * epa.el (epa-sign-keys): New command.
125
126         * epg.el (epg-start-sign-keys): New function.
127         (epg-sign-keys): New function.
128         (epg-status-GET_HIDDEN): Enable local quit.
129         (epg-status-GET_BOOL): Ditto.
130         (epg-status-GET_LINE): Ditto.
131
132 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
133
134         * epa.el (epa-list-keys-1): Add 'epa-list-keys property to keylist
135         region.
136
137 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
138
139         * pgg-epg.el (pgg-epg-secret-key-id-list): New variable.
140         (pgg-epg-passphrase-callback): New function.
141
142         * epa.el (epa-select-keys): Added "Cancel" button.
143
144 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
145
146         * epg.el (epg-signature-to-string): New function.
147
148 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
149
150         * epa-file.el (epa-file-write-region): RECIPIENTS is now a list of
151         key objects.
152         * epa-dired.el (epa-dired-do-encrypt): RECIPIENTS is now a list of
153         key objects.
154
155         * epa.el (epa-select-keys): Added MODE argument.
156         (epa-encrypt-file): RECIPIENTS is now a list of key objects.
157
158         * epg.el (epg-status-SIG_CREATED): New function.
159         (epg-start-sign): epg-context-signers is now a list of key objects.
160         (epg-start-encrypt): RECIPIENTS is now a list of key objects.
161
162 2006-04-19  Daiki Ueno  <ueno@unixuser.org>
163
164         * epa.el (epa-verify-file): Show results in minibuffer.
165         * epg.el (epg-debug-buffer): New variable.
166         (epg-flush): New function.
167
168 2006-04-18  Daiki Ueno  <ueno@unixuser.org>
169
170         * epa.el (epa-export-keys): New command.
171         * epg.el (epg-start-export-keys): Accept a list of epg-key object
172         instead of a regexp.
173
174 2006-04-18  Daiki Ueno  <ueno@unixuser.org>
175
176         * epa.el (epa-keys-mode-map): Bind epa-list-keys; epa-import-key.
177         (epa-import-key): New command.
178
179         * epg.el (epg-delete-problem-alist): New constant.
180         (epg-status-DELETE_PROBLEM): New function.
181         (epg-start-delete-key): New function.
182         (epg-delete-key): New function.
183         (epg-wait-for-completion): Add the NO-EOF argument.
184
185 2006-04-18  Daiki Ueno  <ueno@unixuser.org>
186
187         * epg.el (epg-start): Insert the command-line arguments to the
188         debug buffer.
189         (epg-start-encrypt): Wait for BEGIN_ENCRYPTION.
190         (epg-start-delete-key): New function.
191         (epg-delete-key): New function.
192
193         * epa.el (epa-key): New widget.
194         (epa-key-widget-action): New function.
195         (epa-key-widget-value-create): New function.
196         (epa-key-widget-button-face-get): New function.
197         (epa-key-widget-help-echo): New function.
198
199 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
200
201         * epa-file.el (epa-file-write-region): Check if START is a string.
202
203 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
204
205         * epa-file.el: Rewritten with file-name-handler.
206         (epa-file-handler): New variable.
207         (epa-file-enable): New command.
208         (epa-file-disable): New command.
209
210         * epa-setup.el: Call epa-file-enable.
211
212 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
213
214         * epa-file.el (epa-passphrase): New variable.
215         (epa-file-passphrase-callback-function): New function.
216         (epa-find-file): Reset buffer-undo-list; set
217         buffer-file-coding-system to last-coding-system-used after
218         decoding.
219
220 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
221
222         * epa-file.el (epa-write-file): Try to write region to "/" to get
223         last-coding-system-used to be set.
224
225 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
226
227         * epa-file.el: New implementation of epf.el.
228
229         * epf.el: Abolished.
230
231 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
232
233         * epa.el (epa-verify-file): Display verify result.
234
235         * epg.el (epg-invalid-recipients-alist): New variable.
236         (epg-status-INV_RECP): New function.
237         (epg-status-NO_RECP): New function.
238
239         * epa.el (epa-keys-mode-map): Bind epa-decrypt-file,
240         epa-verify-file, epa-sign-file, and epa-encrypt-file.
241         (epa-decrypt-file): New function imported from epa-dired.el.
242         (epa-verify-file): New function imported from epa-dired.el.
243         (epa-sign-file): New function imported from epa-dired.el.
244         (epa-encrypt-file): New function imported from epa-dired.el.
245
246 2006-04-16  Daiki Ueno  <ueno@unixuser.org>
247
248         * epa.el (epa-select-keys): Renamed from epa-ask-keys; use
249         recursive-edit.
250         * epa-dired.el (epa-dired-encrypt-file): Use epa-select-keys.
251
252 2006-04-16  Daiki Ueno  <ueno@unixuser.org>
253
254         * epa-setup.el: New file.
255         * epa-dired.el: New file.
256
257         * epg.el (epg-colons-pub-spec): Abolished.
258         (epg-colons-sec-spec): Abolished.
259         (epg-colons-uid-spec): Abolished.
260         (epg-colons-fpr-spec): Abolished.
261         (epg-key-validity-alist): New variable.
262         (epg-key-capablity-alist): New variable.
263         (epg-make-key): New object epg-key.
264         (epg-make-sub-key): New object epg-sub-key.
265         (epg-make-user-id): New object epg-user-id.
266         (epg-list-keys-1): Renamed from epg-list-keys.
267         (epg-list-keys): Rewritten.
268
269 2006-04-15  Daiki Ueno  <ueno@unixuser.org>
270
271         * epg.el (epg-list-keys): Make the NAME argument optional.
272
273 2006-04-13  Daiki Ueno  <ueno@unixuser.org>
274
275         * epa.el: Added header.
276
277         * epg.el (epg-list-keys): Specify --with-fingerprint.
278         (epg-colons-fpr-spec): New variable.
279         (epg-colons-pub-spec): Renamed trust -> validity and ownertrust ->
280         owner-trust.
281         (epg-colons-sec-spec): Ditto.
282         (epg-colons-uid-spec): Renamed trust -> validity.
283
284 2006-04-13  Daiki Ueno  <ueno@unixuser.org>
285
286         * epa.el: New file.
287
288         * epg.el (epg-cipher-algorithm-alist): New constant.
289         (epg-pubkey-algorithm-alist): New constant.
290         (epg-digest-algorithm-alist): New constant.
291         (epg-compress-algorithm-alist): New constant.
292         (epg-configuration): New function.
293         (epg-start): Don't specify --yes.
294
295 2006-04-13  Daiki Ueno  <ueno@unixuser.org>
296
297         * epg.el (epg-make-data-from-file): New function.
298         (epg-make-data-from-string): New function.
299         (epg-data-file): New function.
300         (epg-data-string): New function.
301         (epg-start-decrypt): Get a cipher text from a data object.
302         (epg-delete-output-file): New function.
303         (epg-decrypt-file): Add the 3rd argument PLAIN to specify where
304         the output goes.
305         (epg-start-verify): Get a signature and signed-text from a data
306         object.
307         (epg-verify-file): Added the 3rd argument PLAIN to specify where
308         the output goes; return the plain text if PLAIN is nil.
309         (epg-verify-string): Return the plain text.
310         (epg-start-sign): Get a plain text from a data object.
311         (epg-sign-file): Added the 3rd argument SIGNATURE to specify where
312         the output goes.
313         (epg-start-encrypt): Get a plain text from a data object.
314         (epg-encrypt-file): Added the 4th argument CIPHER to specify where
315         the output goes.
316         (epg-start-import-keys): Get keys from a data object.
317         (epg-import-keys-1): New function.
318         (epg-import-keys-from-file): Use it.
319         (epg-import-keys-from-string): Use it.
320
321 2006-04-12  Daiki Ueno  <ueno@unixuser.org>
322
323         * epf.el: Renamed from epg-file.el.
324
325 2006-04-12  Daiki Ueno  <ueno@unixuser.org>
326
327         * epg.el (epg-status-GET_BOOL): New function.
328         (epg-status-GET_LINE): New function.
329         (epg-prompt-alist): New variable, to be filled.
330
331         * pgg-epg.el (mml2015-gpg-extract-signature-details): New function.
332         * epg.el (epg-signature-fingerprint): New function.
333         (epg-signature-set-fingerprint): New function.
334         (epg-status-VALIDSIG): New function.
335
336         * epg.el (epg-reset): Don't reset result.
337         (epg-start-decrypt): Reset result before epg-start.
338         (epg-start-verify): Ditto.
339         (epg-start-sign): Ditto.
340         (epg-start-encrypt): Ditto.
341         (epg-start-export-keys): Ditto.
342         (epg-start-import-keys): Ditto.
343
344         * Makefile.am (EXTRA_DIST): Added pgg-epg.el.
345         * pgg-epg.el: New file.
346
347         * epg.el (epg-start-export-keys): New function.
348         (epg-export-keys): New function.
349         (epg-start-import-keys): New function.
350         (epg-import-keys): New function.
351         (epg-verify-file): New function.
352
353         * epg-file.el (epg-file-write-region): Support public key encryption.
354
355         * epg.el (epg-passphrase-callback-function): Always display key-id.
356