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