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