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