OSDN Git Service

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