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