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