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