* epa-setup.el (epa-mail-mode): Autoload.
[elisp/epg.git] / ChangeLog
1 2007-01-29  Daiki Ueno  <ueno@unixuser.org>
2
3         * epa-setup.el (epa-mail-mode): Autoload.
4         * epa.el: Removed epa-*-mail stuff.
5         * Makefile.am (EXTRA_DIST): Added epa-mail.el.
6         * COMPILE (epg-modules): Added epa-mail.
7         * epa-mail.el: New file.
8
9 2007-01-05  Daiki Ueno  <ueno@unixuser.org>
10
11         * epg-pgp50i.el: Removed.
12
13         * epa.el (epa-key-list-mode-map): Renamed from epa-keys-mode-map.
14         (epa-key-list-mode): Renamed from epa-keys-mode.  All callers
15         changed.
16
17         * epg.el (epg--status-VALIDSIG): Don't set expiration-time if it
18         is "0".
19         (epg--make-sub-key-1): Ditto.
20         (epg--decode-hexstring): "\\x" -> "\\\\x".
21         (epg--decode-quotedstring): Ditto.
22
23         * pgg-epg.el (pgg-epg-encrypt-region): Ask a user whether to skip a
24         recipient whose public key is not available.
25         * epa.el (epa-encrypt-mail): Ask a user whether to skip a
26         recipient whose public key is not available.
27
28 2007-01-04  Daiki Ueno  <ueno@unixuser.org>
29
30         * epa.el (epa-decrypt-mail): Renamed from epa-decrypt.
31         (epa-verify-mail): Renamed from epa-verify.
32         (epa-sign-mail): Renamed from epa-sign.
33         (epa-encrypt-mail): Renamed from epa-encrypt.
34         (epa-import-mail): Renamed from epa-import.
35
36         * configure.ac: Don't exit if GnuPG (>= 1.4.3) is unavailable.
37
38         * epg.el (epg-signature-to-string): Print creation-time and used
39         pubkey-algorithm.
40         (epg-sign-string): If the GnuPG version is earlier than 1.4.3,
41         fallback to use a temp file as an input.
42         (epg-encrypt-string): Ditto.
43
44 2006-12-31  Daiki Ueno  <ueno@unixuser.org>
45
46         * epa.el (epa-mail-modes): New user option.
47         (epa--mail-mode-p): New function.
48         (epa-sign): Use it.
49         (epa-encrypt): Use it.
50         (epa--find-coding-system-for-mime-charset): New function.
51         (epa-decrypt-armor-in-region): Use it.
52         (epa-progress-callback-function): Use handback as the prompt.
53         (epa-encrypt-region): Take 4th argument SIGN.
54         (epa-encrypt): Ditto.
55
56 2006-12-31  Daiki Ueno  <ueno@unixuser.org>
57
58         * epa.el (epa--derived-mode-p): New alias.
59         (epa-sign): Use it.
60         (epa-encrypt): Use it.
61
62 2006-12-31  Daiki Ueno  <ueno@unixuser.org>
63
64         * epa.el (epa--read-signature-type): New function.
65         (epa-decrypt): New command.
66         (epa-verify): New command.
67         (epa-sign): New command.
68         (epa-encrypt): New command.
69         (epa-import-armor-in-region): New command.
70         (epa-import): New command.
71         (epa-decrypt-region): Confirm user to replace the region.
72         (epa-display-info): Delete "*Info*" window.
73
74 2006-12-29  Daiki Ueno  <ueno@unixuser.org>
75
76         * EasyPG: Version 0.0.9 released.
77         * epg-config.el (epg-version-number): Bump up.
78         * configure.ac: Bump up version.
79
80 2006-12-28  Daiki Ueno  <ueno@unixuser.org>
81
82         * epa.el (epa-sign-file): Ask signing key only when a prefix arg
83         is given; ask signature type only when a prefix arg is given.
84         (epa-sign-region): Ditto.
85
86 2006-12-26  Daiki Ueno  <ueno@unixuser.org>
87
88         * epg-config.el (epg-passphrase-coding-system): Default to nil.
89
90 2006-12-20  Hiroya Murata  <lapis-lazuli@pop06.odn.ne.jp>
91
92         * epa.el (epa--format-fingerprint-1): New function.
93         (epa--format-fingerprint): Ditto.
94         (epa--show-key): Use it.
95
96 2006-12-20  Daiki Ueno  <ueno@unixuser.org>
97
98         * epa-file.el (epa-file-write-region): Don't attempt to write the
99         region to "/" to determine safe coding-system.
100
101         * epa.el (epa-list-keys): Abolished PROTOCOL arg.
102         (epa-sign-file): Save the output to *.p7s or *.p7m file if
103         epa-protocol is CMS.
104         (epa-encrypt-file): Ditto.
105         (epa-last-coding-system-specified): New variable.
106         (epa-decrypt-region): Try to decode with the
107         epa-coding-system-used text property.
108         (epa--select-safe-coding-system): New function.
109         (epa-verify-region): Try to decode with the epa-coding-system-used
110         text property.
111         (epa-sign-region): Query user to select coding-system to encode;
112         set the epa-coding-system-used text property on the result.
113         (epa-encrypt-region): Ditto.
114
115 2006-12-19  Daiki Ueno  <ueno@unixuser.org>
116
117         * epg.el (epg-export-keys-to-file): Fixed a typo.
118
119         * epa.el (epa-protocol): New user option.
120         (epa-sign-region): --armor & --textmode.
121         (epa-encrypt-region): Ditto.
122         (epa-list-keys): If prefix-arg is specified, use "OpenPGP" as the
123         default protocol.
124         (epa-import-keys-region): New command.
125         (epa-insert-keys): New command.
126         (epa--insert-keys): Renamed from epa-insert-keys.
127
128 2006-12-11  Daiki Ueno  <ueno@unixuser.org>
129
130         * pgg-epg.el (pgg-epg-decrypt-region): Don't call
131         decode-coding-string if it is not bound.
132
133         * epa-file.el (epa-file--encode-coding-string): New alias.
134         (epa-file--decode-coding-string): New alias.
135         (epa-file-write-region): Use epa-file--encode-coding-string.
136         (epa-file-decode-and-insert): Use epa-file--decode-coding-string.
137
138         * epa.el (epa--encode-coding-string): New alias.
139         (epa--decode-coding-string): New alias.
140         (epa-verify-region): Use epa--encode-coding-string.
141         (epa-sign-region): Ditto; use epa--decode-coding-string.
142         (epa-encrypt-region): Use epa--encode-coding-string.
143
144         * epg.el (epg--encode-coding-string): New alias.
145         (epg--status-GET_HIDDEN): Use it.
146
147 2006-11-29  Daiki Ueno  <ueno@unixuser.org>
148
149         * EasyPG: Version 0.0.8 released.
150         * epg-config.el (epg-version-number): Bump up.
151         * configure.ac: Bump up version.
152
153 2006-11-20  Andreas Seltenreich <uwi7@rz.uni-karlsruhe.de>
154
155         * epa-file.el (epa-file-encrypt-to): New file local variable.
156         (epa-file-write-region): Specify recipients by epa-file-encrypt-to.
157
158 2006-11-26  Daiki Ueno  <ueno@unixuser.org>
159
160         * epa.el (epa-sign-file): Query signature type at a time.
161         (epa-decrypt-file): Display output file name on completion.
162         (epa-sign-file): Ditto.
163         (epa-encrypt-file): Ditto.
164
165 2006-11-25  Daiki Ueno  <ueno@unixuser.org>
166
167         * epa.el (epa-keys-mode): Don't call widget-setup.
168         (epa-list-keys): Call widget-setup here.
169         (epa-select-keys): Ditto.
170
171 2006-11-24  Hiroya Murata  <lapis-lazuli@pop06.odn.ne.jp>
172
173         * epg.el (epg-delete-keys): Remove redundant argument for `error'
174         and fix a close parenthesis.
175
176 2006-11-24  Daiki Ueno  <ueno@unixuser.org>
177
178         * epg.el (epg--status-GET_HIDDEN): Encode passphrase with eol-type LF.
179         Reported by Hiroya Murata  <lapis-lazuli@pop06.odn.ne.jp>.
180         cf. <emacs-mime-ja:02090>
181
182 2006-11-23  Daiki Ueno  <ueno@unixuser.org>
183
184         * epa.el (epa-sign-region): Query signature type at a time.
185
186 2006-11-22  Hiroya Murata  <lapis-lazuli@pop06.odn.ne.jp>
187
188         * epg.el (epg-context-set-passphrase-callback): Add optional
189         argument `handback'.
190         (epg-context-set-progress-callback): Ditto.
191
192 2006-11-14  Daiki Ueno  <ueno@unixuser.org>
193
194         * epa.el (epa--key-widget-value-create): Allow empty user IDs.
195         (epa--show-key): Ditto.
196         Reported by Werner Koch <wk@gnupg.org>.
197
198         * epg.el (epg--start): Don't specify --enable-progress-filter for
199         gpgsm.
200         (epg--status-PROGRESS): Check if progress-callback is set.
201
202 2006-11-12  Daiki Ueno  <ueno@unixuser.org>
203
204         * epg.el (epg-error): New error.
205         (epg--check-error-for-decrypt): New function.
206         (epg-decrypt-file): Use it.
207         (epg-decrypt-string): Use it.
208         (epg--start): Added a very basic test to check whether to specify
209         --use-agent.
210
211         * epa.el (epa-decrypt-file): Expand file name.
212         (epa-verify-file): Ditto.
213         (epa-import-keys): Ditto.
214
215 2006-11-12  Daiki Ueno  <ueno@unixuser.org>
216
217         * epg.el (epg-delete-keys): Decode delete-problem.
218
219         * epa.el (epa-popup-info-window): Turn on by default.
220         (epa-display-info): Split selected window instead of pop-to-buffer.
221
222 2006-11-12  Daiki Ueno  <ueno@unixuser.org>
223
224         * epa.el (epa-display-info): Generalized; renamed from
225         epa-display-verify-result.
226         (epa-decrypt-file): Use it.
227         (epa-verify-file): Use it.
228         (epa-decrypt-region): Use it.
229         (epa-verify-region): Use it.
230         (epa-import-keys): Show import result.
231         (epa-display-verify-result): Make it obsolete.
232
233         * epg.el (epg-start-sign-keys): Make it obsolete; signing a key is
234         out of scope.
235         (epg-sign-keys): Make it obsolete.
236         (epg-make-import-status): New object epg-import-status.
237         (epg-make-import-result): New object epg-import-result.
238         (epg--status-IMPORT_RES): New function.
239         (epg-import-result-to-string): New function.
240
241         * epa.el (epa-keys-mode-map): Don't bind epa-sign-keys.
242         (epa-sign-keys): Make it obsolete.
243
244 2006-11-11  Daiki Ueno  <ueno@unixuser.org>
245
246         * epg.el (epg-start-sign): Don't set --armor nor --textmode if
247         mode is set for a cleartext signature.
248         (epg-make-context): New slot "sig-notations".
249         (epg--args-from-sig-notations): New function.
250         (epg-start-sign): Specify --sig-notation or --sig-policy-url if
251         desired.
252         (epg-start-encrypt): Ditto.
253         (epg-make-signature): New slot "notations".
254         (epg--status-NOTATION_NAME): New function.
255         (epg--status-NOTATION_DATA): New function.
256         (epg--status-POLICY_URL): New function.
257
258 2006-10-29  Daiki Ueno  <ueno@unixuser.org>
259
260         * EasyPG: Version 0.0.7 released.
261         * epg-config.el (epg-version-number): Bump up.
262         * configure.ac: Bump up version.
263
264 2006-10-29  Daiki Ueno  <ueno@unixuser.org>
265
266         * epa-file.el
267         (epa-file-cache-passphrase-for-symmetric-encryption): New user
268         option.
269
270 2006-10-12  Daiki Ueno  <ueno@unixuser.org>
271
272         * epg.el (epg-start-verify): Fixed a clearsign verification bug.
273         Reported by Hirohisa Yamaguchi <umq@ueo.co.jp>.
274
275 2006-09-29  Daiki Ueno  <ueno@unixuser.org>
276
277         * EasyPG: Version 0.0.6 released.
278         * epg.el (epg-version-number): Bump up.
279         * configure.ac: Bump up version.
280
281 2006-09-29  Daiki Ueno  <ueno@unixuser.org>
282
283         * epa.el (epa-verify-cleartext-in-region): Renamed from
284         epa-verify-armor-in-region.
285
286         * epg.el (epg-passphrase-callback-function): Suggest to use
287         epa-passphrase-callback-function instead.
288         (epg-start-verify): Don't specify --verify if SIGNATURE is a
289         normal or a clear text signature.
290         (epg-verify-file): Mention that the plaintext will be stored into
291         the file PLAIN after successful verification.
292         (epg-verify-string): Mention that the plaintext will be returned
293         after successful verification.
294
295 2006-09-27  Daiki Ueno  <ueno@unixuser.org>
296
297         * epa-file.el (epa-file-insert-file-contents): Set progress callback.
298         (epa-file-write-region): Ditto.
299
300         * epa.el (epa-decrypt-file): Set callbacks.
301         (epa-sign-file): Ditto.
302         (epa-encrypt-file): Ditto.
303         (epa-decrypt-region): Ditto.
304         (epa-sign-region): Ditto.
305         (epa-encrypt-region): Ditto.
306         (epa-sign-keys): Ditto.
307
308         * epg.el (epg-progress-callback-function): Removed.
309
310 2006-09-24  Daiki Ueno  <ueno@unixuser.org>
311
312         * epa.el (epa-passphrase-callback-function): Moved from epg.el.
313         (epa-progress-callback-function): Ditto.
314         * epg.el (epg-passphrase-callback-function): Made it obsolete.
315         (epg-progress-callback-function): Ditto.
316
317 2006-09-23  Daiki Ueno  <ueno@unixuser.org>
318
319         * epg.el (epg-start-decrypt): Append "--" to the end of options.
320         (epg-start-verify): Ditto.
321         (epg-start-sign): Ditto.
322         (epg-start-encrypt): Ditto.
323         (epg-start-import-keys): Ditto.
324         (epg-start-generate-key): Ditto.
325
326 2006-09-23  Daiki Ueno  <ueno@unixuser.org>
327
328         * epg.el (epg-make-context): Don't set progress-callback by
329         default.
330         (epg--start): Don't specify --enable-progress-filter if
331         progress-callback is not set.
332         (epg--status-GET_HIDDEN): Signal an error if passphrase-callback
333         is not set.
334
335 2006-09-15  Daiki Ueno  <ueno@unixuser.org>
336
337         * epg.el (epg-progress-callback-function): Show the percentage.
338
339 2006-09-15  Juliusz Chroboczek <Juliusz.Chroboczek@pps.jussieu.fr>
340
341         * pgg-epg.el (mml2015-gpg-extract-signature-details): Fixed a typo.
342
343 2006-09-13  Daiki Ueno  <ueno@unixuser.org>
344
345         * epg-config.el (epg-passphrase-coding-system): Renamed from
346         epg-locale-coding-system.
347
348 2006-09-11  Daiki Ueno  <ueno@unixuser.org>
349
350         * epa-file.el (epa-file-decode-and-insert): New function which
351         utilizes decode-coding-inserted-region if available.
352         (epa-file-insert-file-contents): Use it.
353
354         * epg.el (epg--start): Specify --enable-progress-filter in
355         imitation of GPGME.
356         (epg-progress-callback-function): Remove a couple of %%'s.
357
358 2006-09-05  Hiroya Murata  <lapis-lazuli@pop06.odn.ne.jp>
359
360         * epg-config.el (epg-configuration): Fixed the last change;
361         collect configuration other than group and algorithm.
362
363 2006-09-05  Daiki Ueno  <ueno@unixuser.org>
364
365         * epg-config.el (epg-debug): Moved from epg.el.
366         (epg-configuration): Parse group configuration.
367         (epg-expand-group): New function.
368
369 2006-09-04  Daiki Ueno  <ueno@unixuser.org>
370
371         * EasyPG: Version 0.0.5 released.
372         * epg.el (epg-version-number): Bump up.
373         * configure.ac: Bump up version.
374
375 2006-09-04  Daiki Ueno  <ueno@unixuser.org>
376
377         * epg-config.el (epg-locale-coding-system): New user option.
378
379         * epg.el (epg--list-keys-1): Respect epg-gpg-home-directory.
380         (epg--clear-string): New function.
381         (epg--status-GET_HIDDEN): Encode passphrase with
382         terminal-coding-system.
383
384         * epg-config.el (epg-gpg-minimum-version): New constant.
385         (epg-config--parse-version): New function.
386         (epg-config--compare-version): New function.
387         (epg-configuration): Respect epg-gpg-home-directory.
388
389 2006-09-03  Daiki Ueno  <ueno@unixuser.org>
390
391         * epg-config.el: New file; moved GnuPG configuration check from
392         epg.el.
393
394 2006-09-02  Daiki Ueno  <ueno@unixuser.org>
395
396         * epg.el (epg-check-configuration): New function.
397         (epg-gpg-home-directory): New user option.
398
399         * pgg-epg.el (pgg-epg-lookup-key): New function.
400
401 2006-07-29  Daiki Ueno  <ueno@unixuser.org>
402
403         * EasyPG: Version 0.0.4 released.
404         * epg.el (epg-version-number): Bump up.
405         * configure.ac: Bump up version.
406
407 2006-07-29  Daiki Ueno  <ueno@unixuser.org>
408
409         * acinclude.m4 (AC_CHECK_GPG): Run $3 if there is no gpg executable.
410
411 2006-07-28  Daiki Ueno  <ueno@unixuser.org>
412
413         * epg.el (epg-start-encrypt): Extract primary key ID from
414         epg-context-signers.
415         Thanks to Steve Youngs <steve@sxemacs.org>
416
417         * pgg-epg.el (pgg-epg-encrypt-region): Fixed a bug; it didn't
418         give CONTEXT to epg-list-keys.
419         Thanks to Steve Youngs <steve@sxemacs.org>
420
421 2006-07-18  Daiki Ueno  <ueno@unixuser.org>
422
423         * epg-pgp50i.el (epg-pgp50i--process-filter): Use
424         epg-process-filter-running instead of epg-pgp50i-status; Don't
425         save-excursion during handler execution.
426         (epg-pgp50i--read-line): Renamed from epg-pgp50i--wait-for-line;
427         don't allow process input.
428         (epg-pgp50i--parse-time): New function.
429         (epg-pgp50i--status-BAD_SIGNATURE): New function.
430
431         * epg.el (epg--process-filter): Don't save-excursion during
432         handler execution.
433
434 2006-07-18  Daiki Ueno  <ueno@unixuser.org>
435
436         * acinclude.m4 (AC_CHECK_GPG): Renamed from AC_PATH_GPG.
437
438         * epg.el (epg-process-filter-running): New variable.
439         (epg--start): Setup epg-process-filter-running.
440         (epg--process-filter): Allow only one status handler to run at a
441         time; update epg-read-point everytime the point changes.
442
443 2006-07-14  Daiki Ueno  <ueno@unixuser.org>
444
445         * epg-pgp50i.el: New file.
446
447 2006-07-13  Daiki Ueno  <ueno@unixuser.org>
448
449         * acinclude.m4 (AC_PATH_GPG): New macro.
450         * configure.ac: Check gpg version.
451         Suggested by Max Froumentin <max@lapin-bleu.net>
452
453 2006-07-10  Daiki Ueno  <ueno@unixuser.org>
454
455         * epg.el (epg--status-ERRSIG): Don't remove the last verify-result.
456         (epg-signature-to-string): Remove a trailing whitespace.
457
458         * epa.el (epa-keys-mode-map): Bind return to epa-toggle-mark.
459         (epa-toggle-mark): New command.
460
461 2006-07-04  Daiki Ueno  <ueno@unixuser.org>
462
463         * pgg-epg.el (pgg-epg-sign-region): Select the signing key matched
464         with pgg-default-user-id.
465         Reported by Elias Oltmanns <oltmanns@uni-bonn.de>
466
467 2006-07-01  Daiki Ueno  <ueno@unixuser.org>
468
469         * epa.el (epa-select-keys): If SECRET is specified, select a
470         primary secret key by default.
471
472 2006-06-29  Daiki Ueno  <ueno@unixuser.org>
473
474         * EasyPG: Version 0.0.3 released.
475         * epg.el (epg-version-number): Bump up.
476         * configure.ac: Bump up version.
477
478 2006-06-12  Daiki Ueno  <ueno@unixuser.org>
479
480         * epa-file.el (epa-file-insert-file-contents): Don't move the
481         point to the end of the inserted region.
482         Reported by doug <douglas.bagley@gmail.com>
483
484 2006-06-01  Daiki Ueno  <ueno@unixuser.org>
485
486         * epa-file.el (epa-file-insert-file-contents): Support partial read.
487
488 2006-05-30  Hiroya Murata  <lapis-lazuli@pop06.odn.ne.jp>
489
490         * epa-file.el (epa-file-write-region): Encode the plain text with
491         coding-system-for-write.
492
493 2006-05-30  Daiki Ueno  <ueno@unixuser.org>
494
495         * epa-file.el (epa-file-insert-file-contents):
496         Decode the decrypted text with coding-system-for-read.
497
498 2006-05-29  Daiki Ueno  <ueno@unixuser.org>
499
500         * EasyPG: Version 0.0.2 released.
501         * epg.el (epg-version-number): Bump up.
502         * configure.ac: Bump up version.
503
504 2006-05-29  Daiki Ueno  <ueno@unixuser.org>
505
506         * epg.el (epg--time-from-seconds): New function.
507         (epg--status-ERRSIG): Convert seconds from epoch to encoded-time.
508         (epg--status-VALIDSIG): Ditto.
509         (epg--status-KEYEXPIRED): Ditto.
510
511 2006-05-28  Daiki Ueno  <ueno@unixuser.org>
512
513         * epg.el (epg-start-import-keys): Don't specify filename if keys
514         is a string data.
515
516 2006-05-27  Daiki Ueno  <ueno@unixuser.org>
517
518         * epg.el (epg--process-filter): Pass epg-context instead of
519         process to status handlers.
520         (epg--status-NO_PUBKEY): Check if the previous signature's key-id
521         matches with the given key-id.
522
523 2006-05-26  Daiki Ueno  <ueno@unixuser.org>
524
525         * epg.el (epg--status-NO_PUBKEY): Replace the previous signature's
526         status from 'error to 'no-pubkey.
527         (epg--status-ERRSIG): Just add 'error signature to the verify result.
528
529         * epa.el (epa-insert-keys): Renamed from epa-list-keys-1; don't
530         disable inhibit-quit here; make text-properties nonsticky.
531         (epa-popup-info-window): New user option.
532         (epa-info-window-height): New user option.
533         (epa-display-verify-result): New function.
534         (epa-decrypt-file): Use it.
535         (epa-verify-file): Use it.
536         (epa-decrypt-region): Use it.
537         (epa-verify-region): Use it.
538
539         * epg.el (epg-make-context): New slot "operation".
540         (epg-passphrase-callback-function): Confirm passphrase when
541         performing symmetric encryption.
542
543 2006-05-25  Daiki Ueno  <ueno@unixuser.org>
544
545         * epa.el (epa-decrypt-file): Display verify result if the message
546         is signed.
547         (epa-decrypt-region): New command.
548         (epa-verify-region): New command.
549         (epa-decrypt-armor-in-region): New command.
550         (epa-verify-armor-in-region): New command.
551         (epa-sign-region): New command.
552         (epa-encrypt-region): New command.
553
554 2006-05-11  Daiki Ueno  <ueno@unixuser.org>
555
556         * epa.el (epa-armor): New user option.
557         (epa-textmode): New user option.
558
559 2006-05-02  Daiki Ueno  <ueno@unixuser.org>
560
561         * epg.el (epg-make-key-signature): New object epg-key-signature.
562         (epg-list-keys): Collect key signatures.
563         (epg-make-sub-key): Renamed secret -> secret-p.
564         (epg-list-keys-postprocess-one-key): Abolished.
565         (epg-list-keys): Reverse all keys, sub-keys, user-ids, and key
566         signatures by itself.
567         (epg-no-data-reason-alist): New constant.
568         (epg-unexpected-reason-alist): New constant.
569
570 2006-05-01  Daiki Ueno  <ueno@unixuser.org>
571
572         * epg.el (epg-invalid-recipients-reason-alist): Renamed.
573         (epg-delete-problem-reason-alist): Renamed.
574         (epg-import-ok-reason-alist): New constant.
575         (epg-import-problem-reason-alist): New constant.
576         (epg-status-IMPORTED): New function.
577         (epg-status-IMPORT_OK): New function.
578         (epg-status-IMPORT_PROBLEM): New function.
579         (epg-start-import-keys): Don't use a temporary output file.
580         (epg-start-receive-keys): New function.
581         (epg-import-keys-from-server): New function.
582         (epg-receive-keys): Alias to epg-import-keys-from-server.
583
584 2006-05-01  Daiki Ueno  <ueno@unixuser.org>
585
586         * epg.el (epg-start): Signal an error if the process of CONTEXT is
587         already running for other operations.
588         (epg-flush): Abolished.
589         (epg-start-generate-key): New function.
590         (epg-generate-key-from-file): New function.
591         (epg-generate-key-from-string): New function.
592         (epg-status-KEY_CREATED): New function.
593         (epg-status-KEY_NOT_CREATED): New function.
594         (epg-new-signature-type-alist): New variable.
595         (epg-make-new-signature): New object epg-new-signature.
596         (epg-status-SIG_CREATED): Set epg-new-signature object.
597         (epg-new-signature-to-string): New function.
598         (epg-make-signature): Added slots for signature class and version.
599         (epg-start-sign): Fixed rule of the MODE argument.
600
601 2006-04-30  Daiki Ueno  <ueno@unixuser.org>
602
603         * epa.el (epa-delete-keys): Support deletion of secret keys.
604
605         * pgg-epg.el (pgg-epg-decrypt-region): Convert line endings of the
606         decrypted text.
607
608         * epg.el (epg-read-output): Don't convert line endings of the
609         output file.
610         (epg-cancel): Set 'error result.
611
612 2006-04-29  Daiki Ueno  <ueno@unixuser.org>
613
614         * epg.el (epg-make-signature): Removed user-id; added
615         creation-time, expiration-time, pubkey-algorithm,
616         digest-algorithm.
617         (epg-process-sentinel): Abolished.
618         (epg-signature-to-string): Decode DN.
619         (epg-list-keys): Cache user-id in epg-user-id-alist.
620         (epg-make-user-id): Renamed name -> string.
621
622 2006-04-29  Daiki Ueno  <ueno@unixuser.org>
623
624         * epg.el (epg-status-ERRSIG): New function.
625         (epg-verify-file): Signal an error if we encounter ERRSIG status.
626         (epg-verify-string): Ditto.
627
628 2006-04-28  Daiki Ueno  <ueno@unixuser.org>
629
630         * epg.el: Added typecheck to accessors to objects.
631
632 2006-04-26  Daiki Ueno  <ueno@unixuser.org>
633
634         * epg.el (epg-status-GET_HIDDEN): Pass epg-context as the first
635         argument of passphrase-callback.
636         (epg-status-PROGRESS): Ditto.
637
638 2006-04-26  Daiki Ueno  <ueno@unixuser.org>
639
640         * epa.el (epa-select-keys): Don't set inhibit-quit when
641         recursive-edit is called.
642         (epg-cancel): New function.
643
644 2006-04-25  Daiki Ueno  <ueno@unixuser.org>
645
646         * epg.el (epg-process-sentinel): New function; set 'error if gpg
647         process exited abnormally, but we have not received an error
648         response from it.
649         (epg-sign-file): Signal an error only when a signature is not
650         created.
651         (epg-sign-string): Ditto.
652         (epg-encrypt-file): Signal an error if SIGN is specified and
653         signature is not created.
654         (epg-encrypt-string): Ditto.
655
656 2006-04-22  Daiki Ueno  <ueno@unixuser.org>
657
658         * epa.el (epa-key-widget-value-create): Decode DN.
659         (epa-list-keys): Add the PROTOCOL argument.
660         (epa-select-keys): Require CONTEXT as the first argument.
661
662         * epg.el (epg-gpgsm-program): New user option.
663         (epg-dn-type-alist): New variable.
664         (epg-start): Don't specify --command-fd if protocol is CMS.
665         (epg-list-keys): Require CONTEXT as the first argument.
666         (epg-dn-from-string): New function.
667         (epg-decode-dn): New function.
668
669 2006-04-21  Daiki Ueno  <ueno@unixuser.org>
670
671         * epa.el (epa-sign-keys): New command.
672
673         * epg.el (epg-start-sign-keys): New function.
674         (epg-sign-keys): New function.
675         (epg-status-GET_HIDDEN): Enable local quit.
676         (epg-status-GET_BOOL): Ditto.
677         (epg-status-GET_LINE): Ditto.
678
679 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
680
681         * epa.el (epa-list-keys-1): Add 'epa-list-keys property to keylist
682         region.
683
684 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
685
686         * pgg-epg.el (pgg-epg-secret-key-id-list): New variable.
687         (pgg-epg-passphrase-callback): New function.
688
689         * epa.el (epa-select-keys): Added "Cancel" button.
690
691 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
692
693         * epg.el (epg-signature-to-string): New function.
694
695 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
696
697         * epa-file.el (epa-file-write-region): RECIPIENTS is now a list of
698         key objects.
699         * epa-dired.el (epa-dired-do-encrypt): RECIPIENTS is now a list of
700         key objects.
701
702         * epa.el (epa-select-keys): Added MODE argument.
703         (epa-encrypt-file): RECIPIENTS is now a list of key objects.
704
705         * epg.el (epg-status-SIG_CREATED): New function.
706         (epg-start-sign): epg-context-signers is now a list of key objects.
707         (epg-start-encrypt): RECIPIENTS is now a list of key objects.
708
709 2006-04-19  Daiki Ueno  <ueno@unixuser.org>
710
711         * epa.el (epa-verify-file): Show results in minibuffer.
712         * epg.el (epg-debug-buffer): New variable.
713         (epg-flush): New function.
714
715 2006-04-18  Daiki Ueno  <ueno@unixuser.org>
716
717         * epa.el (epa-export-keys): New command.
718         * epg.el (epg-start-export-keys): Accept a list of epg-key object
719         instead of a regexp.
720
721 2006-04-18  Daiki Ueno  <ueno@unixuser.org>
722
723         * epa.el (epa-keys-mode-map): Bind epa-list-keys; epa-import-key.
724         (epa-import-key): New command.
725
726         * epg.el (epg-delete-problem-alist): New constant.
727         (epg-status-DELETE_PROBLEM): New function.
728         (epg-start-delete-key): New function.
729         (epg-delete-key): New function.
730         (epg-wait-for-completion): Add the NO-EOF argument.
731
732 2006-04-18  Daiki Ueno  <ueno@unixuser.org>
733
734         * epg.el (epg-start): Insert the command-line arguments to the
735         debug buffer.
736         (epg-start-encrypt): Wait for BEGIN_ENCRYPTION.
737         (epg-start-delete-key): New function.
738         (epg-delete-key): New function.
739
740         * epa.el (epa-key): New widget.
741         (epa-key-widget-action): New function.
742         (epa-key-widget-value-create): New function.
743         (epa-key-widget-button-face-get): New function.
744         (epa-key-widget-help-echo): New function.
745
746 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
747
748         * epa-file.el (epa-file-write-region): Check if START is a string.
749
750 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
751
752         * epa-file.el: Rewritten with file-name-handler.
753         (epa-file-handler): New variable.
754         (epa-file-enable): New command.
755         (epa-file-disable): New command.
756
757         * epa-setup.el: Call epa-file-enable.
758
759 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
760
761         * epa-file.el (epa-passphrase): New variable.
762         (epa-file-passphrase-callback-function): New function.
763         (epa-find-file): Reset buffer-undo-list; set
764         buffer-file-coding-system to last-coding-system-used after
765         decoding.
766
767 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
768
769         * epa-file.el (epa-write-file): Try to write region to "/" to get
770         last-coding-system-used to be set.
771
772 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
773
774         * epa-file.el: New implementation of epf.el.
775
776         * epf.el: Abolished.
777
778 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
779
780         * epa.el (epa-verify-file): Display verify result.
781
782         * epg.el (epg-invalid-recipients-alist): New variable.
783         (epg-status-INV_RECP): New function.
784         (epg-status-NO_RECP): New function.
785
786         * epa.el (epa-keys-mode-map): Bind epa-decrypt-file,
787         epa-verify-file, epa-sign-file, and epa-encrypt-file.
788         (epa-decrypt-file): New function imported from epa-dired.el.
789         (epa-verify-file): New function imported from epa-dired.el.
790         (epa-sign-file): New function imported from epa-dired.el.
791         (epa-encrypt-file): New function imported from epa-dired.el.
792
793 2006-04-16  Daiki Ueno  <ueno@unixuser.org>
794
795         * epa.el (epa-select-keys): Renamed from epa-ask-keys; use
796         recursive-edit.
797         * epa-dired.el (epa-dired-encrypt-file): Use epa-select-keys.
798
799 2006-04-16  Daiki Ueno  <ueno@unixuser.org>
800
801         * epa-setup.el: New file.
802         * epa-dired.el: New file.
803
804         * epg.el (epg-colons-pub-spec): Abolished.
805         (epg-colons-sec-spec): Abolished.
806         (epg-colons-uid-spec): Abolished.
807         (epg-colons-fpr-spec): Abolished.
808         (epg-key-validity-alist): New variable.
809         (epg-key-capablity-alist): New variable.
810         (epg-make-key): New object epg-key.
811         (epg-make-sub-key): New object epg-sub-key.
812         (epg-make-user-id): New object epg-user-id.
813         (epg-list-keys-1): Renamed from epg-list-keys.
814         (epg-list-keys): Rewritten.
815
816 2006-04-15  Daiki Ueno  <ueno@unixuser.org>
817
818         * epg.el (epg-list-keys): Make the NAME argument optional.
819
820 2006-04-13  Daiki Ueno  <ueno@unixuser.org>
821
822         * epa.el: Added header.
823
824         * epg.el (epg-list-keys): Specify --with-fingerprint.
825         (epg-colons-fpr-spec): New variable.
826         (epg-colons-pub-spec): Renamed trust -> validity and ownertrust ->
827         owner-trust.
828         (epg-colons-sec-spec): Ditto.
829         (epg-colons-uid-spec): Renamed trust -> validity.
830
831 2006-04-13  Daiki Ueno  <ueno@unixuser.org>
832
833         * epa.el: New file.
834
835         * epg.el (epg-cipher-algorithm-alist): New constant.
836         (epg-pubkey-algorithm-alist): New constant.
837         (epg-digest-algorithm-alist): New constant.
838         (epg-compress-algorithm-alist): New constant.
839         (epg-configuration): New function.
840         (epg-start): Don't specify --yes.
841
842 2006-04-13  Daiki Ueno  <ueno@unixuser.org>
843
844         * epg.el (epg-make-data-from-file): New function.
845         (epg-make-data-from-string): New function.
846         (epg-data-file): New function.
847         (epg-data-string): New function.
848         (epg-start-decrypt): Get a cipher text from a data object.
849         (epg-delete-output-file): New function.
850         (epg-decrypt-file): Add the 3rd argument PLAIN to specify where
851         the output goes.
852         (epg-start-verify): Get a signature and signed-text from a data
853         object.
854         (epg-verify-file): Added the 3rd argument PLAIN to specify where
855         the output goes; return the plain text if PLAIN is nil.
856         (epg-verify-string): Return the plain text.
857         (epg-start-sign): Get a plain text from a data object.
858         (epg-sign-file): Added the 3rd argument SIGNATURE to specify where
859         the output goes.
860         (epg-start-encrypt): Get a plain text from a data object.
861         (epg-encrypt-file): Added the 4th argument CIPHER to specify where
862         the output goes.
863         (epg-start-import-keys): Get keys from a data object.
864         (epg-import-keys-1): New function.
865         (epg-import-keys-from-file): Use it.
866         (epg-import-keys-from-string): Use it.
867
868 2006-04-12  Daiki Ueno  <ueno@unixuser.org>
869
870         * epf.el: Renamed from epg-file.el.
871
872 2006-04-12  Daiki Ueno  <ueno@unixuser.org>
873
874         * epg.el (epg-status-GET_BOOL): New function.
875         (epg-status-GET_LINE): New function.
876         (epg-prompt-alist): New variable, to be filled.
877
878         * pgg-epg.el (mml2015-gpg-extract-signature-details): New function.
879         * epg.el (epg-signature-fingerprint): New function.
880         (epg-signature-set-fingerprint): New function.
881         (epg-status-VALIDSIG): New function.
882
883         * epg.el (epg-reset): Don't reset result.
884         (epg-start-decrypt): Reset result before epg-start.
885         (epg-start-verify): Ditto.
886         (epg-start-sign): Ditto.
887         (epg-start-encrypt): Ditto.
888         (epg-start-export-keys): Ditto.
889         (epg-start-import-keys): Ditto.
890
891         * Makefile.am (EXTRA_DIST): Added pgg-epg.el.
892         * pgg-epg.el: New file.
893
894         * epg.el (epg-start-export-keys): New function.
895         (epg-export-keys): New function.
896         (epg-start-import-keys): New function.
897         (epg-import-keys): New function.
898         (epg-verify-file): New function.
899
900         * epg-file.el (epg-file-write-region): Support public key encryption.
901
902         * epg.el (epg-passphrase-callback-function): Always display key-id.
903