1 2007-01-04 Daiki Ueno <ueno@unixuser.org>
3 * epg.el (epg-signature-to-string): Print creation-time and used
5 (epg-sign-string): If the GnuPG version is earlier than 1.4.3,
6 fallback to use a temp file as an input.
8 2006-12-31 Daiki Ueno <ueno@unixuser.org>
10 * epa.el (epa-mail-modes): New user option.
11 (epa--mail-mode-p): New function.
13 (epa-encrypt): Use it.
14 (epa--find-coding-system-for-mime-charset): New function.
15 (epa-decrypt-armor-in-region): Use it.
16 (epa-progress-callback-function): Use handback as the prompt.
17 (epa-encrypt-region): Take 4th argument SIGN.
20 2006-12-31 Daiki Ueno <ueno@unixuser.org>
22 * epa.el (epa--derived-mode-p): New alias.
24 (epa-encrypt): Use it.
26 2006-12-31 Daiki Ueno <ueno@unixuser.org>
28 * epa.el (epa--read-signature-type): New function.
29 (epa-decrypt): New command.
30 (epa-verify): New command.
31 (epa-sign): New command.
32 (epa-encrypt): New command.
33 (epa-import-armor-in-region): New command.
34 (epa-import): New command.
35 (epa-decrypt-region): Confirm user to replace the region.
36 (epa-display-info): Delete "*Info*" window.
38 2006-12-29 Daiki Ueno <ueno@unixuser.org>
40 * EasyPG: Version 0.0.9 released.
41 * epg-config.el (epg-version-number): Bump up.
42 * configure.ac: Bump up version.
44 2006-12-28 Daiki Ueno <ueno@unixuser.org>
46 * epa.el (epa-sign-file): Ask signing key only when a prefix arg
47 is given; ask signature type only when a prefix arg is given.
48 (epa-sign-region): Ditto.
50 2006-12-26 Daiki Ueno <ueno@unixuser.org>
52 * epg-config.el (epg-passphrase-coding-system): Default to nil.
54 2006-12-20 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
56 * epa.el (epa--format-fingerprint-1): New function.
57 (epa--format-fingerprint): Ditto.
58 (epa--show-key): Use it.
60 2006-12-20 Daiki Ueno <ueno@unixuser.org>
62 * epa-file.el (epa-file-write-region): Don't attempt to write the
63 region to "/" to determine safe coding-system.
65 * epa.el (epa-list-keys): Abolished PROTOCOL arg.
66 (epa-sign-file): Save the output to *.p7s or *.p7m file if
68 (epa-encrypt-file): Ditto.
69 (epa-last-coding-system-specified): New variable.
70 (epa-decrypt-region): Try to decode with the
71 epa-coding-system-used text property.
72 (epa--select-safe-coding-system): New function.
73 (epa-verify-region): Try to decode with the epa-coding-system-used
75 (epa-sign-region): Query user to select coding-system to encode;
76 set the epa-coding-system-used text property on the result.
77 (epa-encrypt-region): Ditto.
79 2006-12-19 Daiki Ueno <ueno@unixuser.org>
81 * epg.el (epg-export-keys-to-file): Fixed a typo.
83 * epa.el (epa-protocol): New user option.
84 (epa-sign-region): --armor & --textmode.
85 (epa-encrypt-region): Ditto.
86 (epa-list-keys): If prefix-arg is specified, use "OpenPGP" as the
88 (epa-import-keys-region): New command.
89 (epa-insert-keys): New command.
90 (epa--insert-keys): Renamed from epa-insert-keys.
92 2006-12-11 Daiki Ueno <ueno@unixuser.org>
94 * pgg-epg.el (pgg-epg-decrypt-region): Don't call
95 decode-coding-string if it is not bound.
97 * epa-file.el (epa-file--encode-coding-string): New alias.
98 (epa-file--decode-coding-string): New alias.
99 (epa-file-write-region): Use epa-file--encode-coding-string.
100 (epa-file-decode-and-insert): Use epa-file--decode-coding-string.
102 * epa.el (epa--encode-coding-string): New alias.
103 (epa--decode-coding-string): New alias.
104 (epa-verify-region): Use epa--encode-coding-string.
105 (epa-sign-region): Ditto; use epa--decode-coding-string.
106 (epa-encrypt-region): Use epa--encode-coding-string.
108 * epg.el (epg--encode-coding-string): New alias.
109 (epg--status-GET_HIDDEN): Use it.
111 2006-11-29 Daiki Ueno <ueno@unixuser.org>
113 * EasyPG: Version 0.0.8 released.
114 * epg-config.el (epg-version-number): Bump up.
115 * configure.ac: Bump up version.
117 2006-11-20 Andreas Seltenreich <uwi7@rz.uni-karlsruhe.de>
119 * epa-file.el (epa-file-encrypt-to): New file local variable.
120 (epa-file-write-region): Specify recipients by epa-file-encrypt-to.
122 2006-11-26 Daiki Ueno <ueno@unixuser.org>
124 * epa.el (epa-sign-file): Query signature type at a time.
125 (epa-decrypt-file): Display output file name on completion.
126 (epa-sign-file): Ditto.
127 (epa-encrypt-file): Ditto.
129 2006-11-25 Daiki Ueno <ueno@unixuser.org>
131 * epa.el (epa-keys-mode): Don't call widget-setup.
132 (epa-list-keys): Call widget-setup here.
133 (epa-select-keys): Ditto.
135 2006-11-24 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
137 * epg.el (epg-delete-keys): Remove redundant argument for `error'
138 and fix a close parenthesis.
140 2006-11-24 Daiki Ueno <ueno@unixuser.org>
142 * epg.el (epg--status-GET_HIDDEN): Encode passphrase with eol-type LF.
143 Reported by Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>.
144 cf. <emacs-mime-ja:02090>
146 2006-11-23 Daiki Ueno <ueno@unixuser.org>
148 * epa.el (epa-sign-region): Query signature type at a time.
150 2006-11-22 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
152 * epg.el (epg-context-set-passphrase-callback): Add optional
154 (epg-context-set-progress-callback): Ditto.
156 2006-11-14 Daiki Ueno <ueno@unixuser.org>
158 * epa.el (epa--key-widget-value-create): Allow empty user IDs.
159 (epa--show-key): Ditto.
160 Reported by Werner Koch <wk@gnupg.org>.
162 * epg.el (epg--start): Don't specify --enable-progress-filter for
164 (epg--status-PROGRESS): Check if progress-callback is set.
166 2006-11-12 Daiki Ueno <ueno@unixuser.org>
168 * epg.el (epg-error): New error.
169 (epg--check-error-for-decrypt): New function.
170 (epg-decrypt-file): Use it.
171 (epg-decrypt-string): Use it.
172 (epg--start): Added a very basic test to check whether to specify
175 * epa.el (epa-decrypt-file): Expand file name.
176 (epa-verify-file): Ditto.
177 (epa-import-keys): Ditto.
179 2006-11-12 Daiki Ueno <ueno@unixuser.org>
181 * epg.el (epg-delete-keys): Decode delete-problem.
183 * epa.el (epa-popup-info-window): Turn on by default.
184 (epa-display-info): Split selected window instead of pop-to-buffer.
186 2006-11-12 Daiki Ueno <ueno@unixuser.org>
188 * epa.el (epa-display-info): Generalized; renamed from
189 epa-display-verify-result.
190 (epa-decrypt-file): Use it.
191 (epa-verify-file): Use it.
192 (epa-decrypt-region): Use it.
193 (epa-verify-region): Use it.
194 (epa-import-keys): Show import result.
195 (epa-display-verify-result): Make it obsolete.
197 * epg.el (epg-start-sign-keys): Make it obsolete; signing a key is
199 (epg-sign-keys): Make it obsolete.
200 (epg-make-import-status): New object epg-import-status.
201 (epg-make-import-result): New object epg-import-result.
202 (epg--status-IMPORT_RES): New function.
203 (epg-import-result-to-string): New function.
205 * epa.el (epa-keys-mode-map): Don't bind epa-sign-keys.
206 (epa-sign-keys): Make it obsolete.
208 2006-11-11 Daiki Ueno <ueno@unixuser.org>
210 * epg.el (epg-start-sign): Don't set --armor nor --textmode if
211 mode is set for a cleartext signature.
212 (epg-make-context): New slot "sig-notations".
213 (epg--args-from-sig-notations): New function.
214 (epg-start-sign): Specify --sig-notation or --sig-policy-url if
216 (epg-start-encrypt): Ditto.
217 (epg-make-signature): New slot "notations".
218 (epg--status-NOTATION_NAME): New function.
219 (epg--status-NOTATION_DATA): New function.
220 (epg--status-POLICY_URL): New function.
222 2006-10-29 Daiki Ueno <ueno@unixuser.org>
224 * EasyPG: Version 0.0.7 released.
225 * epg-config.el (epg-version-number): Bump up.
226 * configure.ac: Bump up version.
228 2006-10-29 Daiki Ueno <ueno@unixuser.org>
231 (epa-file-cache-passphrase-for-symmetric-encryption): New user
234 2006-10-12 Daiki Ueno <ueno@unixuser.org>
236 * epg.el (epg-start-verify): Fixed a clearsign verification bug.
237 Reported by Hirohisa Yamaguchi <umq@ueo.co.jp>.
239 2006-09-29 Daiki Ueno <ueno@unixuser.org>
241 * EasyPG: Version 0.0.6 released.
242 * epg.el (epg-version-number): Bump up.
243 * configure.ac: Bump up version.
245 2006-09-29 Daiki Ueno <ueno@unixuser.org>
247 * epa.el (epa-verify-cleartext-in-region): Renamed from
248 epa-verify-armor-in-region.
250 * epg.el (epg-passphrase-callback-function): Suggest to use
251 epa-passphrase-callback-function instead.
252 (epg-start-verify): Don't specify --verify if SIGNATURE is a
253 normal or a clear text signature.
254 (epg-verify-file): Mention that the plaintext will be stored into
255 the file PLAIN after successful verification.
256 (epg-verify-string): Mention that the plaintext will be returned
257 after successful verification.
259 2006-09-27 Daiki Ueno <ueno@unixuser.org>
261 * epa-file.el (epa-file-insert-file-contents): Set progress callback.
262 (epa-file-write-region): Ditto.
264 * epa.el (epa-decrypt-file): Set callbacks.
265 (epa-sign-file): Ditto.
266 (epa-encrypt-file): Ditto.
267 (epa-decrypt-region): Ditto.
268 (epa-sign-region): Ditto.
269 (epa-encrypt-region): Ditto.
270 (epa-sign-keys): Ditto.
272 * epg.el (epg-progress-callback-function): Removed.
274 2006-09-24 Daiki Ueno <ueno@unixuser.org>
276 * epa.el (epa-passphrase-callback-function): Moved from epg.el.
277 (epa-progress-callback-function): Ditto.
278 * epg.el (epg-passphrase-callback-function): Made it obsolete.
279 (epg-progress-callback-function): Ditto.
281 2006-09-23 Daiki Ueno <ueno@unixuser.org>
283 * epg.el (epg-start-decrypt): Append "--" to the end of options.
284 (epg-start-verify): Ditto.
285 (epg-start-sign): Ditto.
286 (epg-start-encrypt): Ditto.
287 (epg-start-import-keys): Ditto.
288 (epg-start-generate-key): Ditto.
290 2006-09-23 Daiki Ueno <ueno@unixuser.org>
292 * epg.el (epg-make-context): Don't set progress-callback by
294 (epg--start): Don't specify --enable-progress-filter if
295 progress-callback is not set.
296 (epg--status-GET_HIDDEN): Signal an error if passphrase-callback
299 2006-09-15 Daiki Ueno <ueno@unixuser.org>
301 * epg.el (epg-progress-callback-function): Show the percentage.
303 2006-09-15 Juliusz Chroboczek <Juliusz.Chroboczek@pps.jussieu.fr>
305 * pgg-epg.el (mml2015-gpg-extract-signature-details): Fixed a typo.
307 2006-09-13 Daiki Ueno <ueno@unixuser.org>
309 * epg-config.el (epg-passphrase-coding-system): Renamed from
310 epg-locale-coding-system.
312 2006-09-11 Daiki Ueno <ueno@unixuser.org>
314 * epa-file.el (epa-file-decode-and-insert): New function which
315 utilizes decode-coding-inserted-region if available.
316 (epa-file-insert-file-contents): Use it.
318 * epg.el (epg--start): Specify --enable-progress-filter in
320 (epg-progress-callback-function): Remove a couple of %%'s.
322 2006-09-05 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
324 * epg-config.el (epg-configuration): Fixed the last change;
325 collect configuration other than group and algorithm.
327 2006-09-05 Daiki Ueno <ueno@unixuser.org>
329 * epg-config.el (epg-debug): Moved from epg.el.
330 (epg-configuration): Parse group configuration.
331 (epg-expand-group): New function.
333 2006-09-04 Daiki Ueno <ueno@unixuser.org>
335 * EasyPG: Version 0.0.5 released.
336 * epg.el (epg-version-number): Bump up.
337 * configure.ac: Bump up version.
339 2006-09-04 Daiki Ueno <ueno@unixuser.org>
341 * epg-config.el (epg-locale-coding-system): New user option.
343 * epg.el (epg--list-keys-1): Respect epg-gpg-home-directory.
344 (epg--clear-string): New function.
345 (epg--status-GET_HIDDEN): Encode passphrase with
346 terminal-coding-system.
348 * epg-config.el (epg-gpg-minimum-version): New constant.
349 (epg-config--parse-version): New function.
350 (epg-config--compare-version): New function.
351 (epg-configuration): Respect epg-gpg-home-directory.
353 2006-09-03 Daiki Ueno <ueno@unixuser.org>
355 * epg-config.el: New file; moved GnuPG configuration check from
358 2006-09-02 Daiki Ueno <ueno@unixuser.org>
360 * epg.el (epg-check-configuration): New function.
361 (epg-gpg-home-directory): New user option.
363 * pgg-epg.el (pgg-epg-lookup-key): New function.
365 2006-07-29 Daiki Ueno <ueno@unixuser.org>
367 * EasyPG: Version 0.0.4 released.
368 * epg.el (epg-version-number): Bump up.
369 * configure.ac: Bump up version.
371 2006-07-29 Daiki Ueno <ueno@unixuser.org>
373 * acinclude.m4 (AC_CHECK_GPG): Run $3 if there is no gpg executable.
375 2006-07-28 Daiki Ueno <ueno@unixuser.org>
377 * epg.el (epg-start-encrypt): Extract primary key ID from
379 Thanks to Steve Youngs <steve@sxemacs.org>
381 * pgg-epg.el (pgg-epg-encrypt-region): Fixed a bug; it didn't
382 give CONTEXT to epg-list-keys.
383 Thanks to Steve Youngs <steve@sxemacs.org>
385 2006-07-18 Daiki Ueno <ueno@unixuser.org>
387 * epg-pgp50i.el (epg-pgp50i--process-filter): Use
388 epg-process-filter-running instead of epg-pgp50i-status; Don't
389 save-excursion during handler execution.
390 (epg-pgp50i--read-line): Renamed from epg-pgp50i--wait-for-line;
391 don't allow process input.
392 (epg-pgp50i--parse-time): New function.
393 (epg-pgp50i--status-BAD_SIGNATURE): New function.
395 * epg.el (epg--process-filter): Don't save-excursion during
398 2006-07-18 Daiki Ueno <ueno@unixuser.org>
400 * acinclude.m4 (AC_CHECK_GPG): Renamed from AC_PATH_GPG.
402 * epg.el (epg-process-filter-running): New variable.
403 (epg--start): Setup epg-process-filter-running.
404 (epg--process-filter): Allow only one status handler to run at a
405 time; update epg-read-point everytime the point changes.
407 2006-07-14 Daiki Ueno <ueno@unixuser.org>
409 * epg-pgp50i.el: New file.
411 2006-07-13 Daiki Ueno <ueno@unixuser.org>
413 * acinclude.m4 (AC_PATH_GPG): New macro.
414 * configure.ac: Check gpg version.
415 Suggested by Max Froumentin <max@lapin-bleu.net>
417 2006-07-10 Daiki Ueno <ueno@unixuser.org>
419 * epg.el (epg--status-ERRSIG): Don't remove the last verify-result.
420 (epg-signature-to-string): Remove a trailing whitespace.
422 * epa.el (epa-keys-mode-map): Bind return to epa-toggle-mark.
423 (epa-toggle-mark): New command.
425 2006-07-04 Daiki Ueno <ueno@unixuser.org>
427 * pgg-epg.el (pgg-epg-sign-region): Select the signing key matched
428 with pgg-default-user-id.
429 Reported by Elias Oltmanns <oltmanns@uni-bonn.de>
431 2006-07-01 Daiki Ueno <ueno@unixuser.org>
433 * epa.el (epa-select-keys): If SECRET is specified, select a
434 primary secret key by default.
436 2006-06-29 Daiki Ueno <ueno@unixuser.org>
438 * EasyPG: Version 0.0.3 released.
439 * epg.el (epg-version-number): Bump up.
440 * configure.ac: Bump up version.
442 2006-06-12 Daiki Ueno <ueno@unixuser.org>
444 * epa-file.el (epa-file-insert-file-contents): Don't move the
445 point to the end of the inserted region.
446 Reported by doug <douglas.bagley@gmail.com>
448 2006-06-01 Daiki Ueno <ueno@unixuser.org>
450 * epa-file.el (epa-file-insert-file-contents): Support partial read.
452 2006-05-30 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
454 * epa-file.el (epa-file-write-region): Encode the plain text with
455 coding-system-for-write.
457 2006-05-30 Daiki Ueno <ueno@unixuser.org>
459 * epa-file.el (epa-file-insert-file-contents):
460 Decode the decrypted text with coding-system-for-read.
462 2006-05-29 Daiki Ueno <ueno@unixuser.org>
464 * EasyPG: Version 0.0.2 released.
465 * epg.el (epg-version-number): Bump up.
466 * configure.ac: Bump up version.
468 2006-05-29 Daiki Ueno <ueno@unixuser.org>
470 * epg.el (epg--time-from-seconds): New function.
471 (epg--status-ERRSIG): Convert seconds from epoch to encoded-time.
472 (epg--status-VALIDSIG): Ditto.
473 (epg--status-KEYEXPIRED): Ditto.
475 2006-05-28 Daiki Ueno <ueno@unixuser.org>
477 * epg.el (epg-start-import-keys): Don't specify filename if keys
480 2006-05-27 Daiki Ueno <ueno@unixuser.org>
482 * epg.el (epg--process-filter): Pass epg-context instead of
483 process to status handlers.
484 (epg--status-NO_PUBKEY): Check if the previous signature's key-id
485 matches with the given key-id.
487 2006-05-26 Daiki Ueno <ueno@unixuser.org>
489 * epg.el (epg--status-NO_PUBKEY): Replace the previous signature's
490 status from 'error to 'no-pubkey.
491 (epg--status-ERRSIG): Just add 'error signature to the verify result.
493 * epa.el (epa-insert-keys): Renamed from epa-list-keys-1; don't
494 disable inhibit-quit here; make text-properties nonsticky.
495 (epa-popup-info-window): New user option.
496 (epa-info-window-height): New user option.
497 (epa-display-verify-result): New function.
498 (epa-decrypt-file): Use it.
499 (epa-verify-file): Use it.
500 (epa-decrypt-region): Use it.
501 (epa-verify-region): Use it.
503 * epg.el (epg-make-context): New slot "operation".
504 (epg-passphrase-callback-function): Confirm passphrase when
505 performing symmetric encryption.
507 2006-05-25 Daiki Ueno <ueno@unixuser.org>
509 * epa.el (epa-decrypt-file): Display verify result if the message
511 (epa-decrypt-region): New command.
512 (epa-verify-region): New command.
513 (epa-decrypt-armor-in-region): New command.
514 (epa-verify-armor-in-region): New command.
515 (epa-sign-region): New command.
516 (epa-encrypt-region): New command.
518 2006-05-11 Daiki Ueno <ueno@unixuser.org>
520 * epa.el (epa-armor): New user option.
521 (epa-textmode): New user option.
523 2006-05-02 Daiki Ueno <ueno@unixuser.org>
525 * epg.el (epg-make-key-signature): New object epg-key-signature.
526 (epg-list-keys): Collect key signatures.
527 (epg-make-sub-key): Renamed secret -> secret-p.
528 (epg-list-keys-postprocess-one-key): Abolished.
529 (epg-list-keys): Reverse all keys, sub-keys, user-ids, and key
530 signatures by itself.
531 (epg-no-data-reason-alist): New constant.
532 (epg-unexpected-reason-alist): New constant.
534 2006-05-01 Daiki Ueno <ueno@unixuser.org>
536 * epg.el (epg-invalid-recipients-reason-alist): Renamed.
537 (epg-delete-problem-reason-alist): Renamed.
538 (epg-import-ok-reason-alist): New constant.
539 (epg-import-problem-reason-alist): New constant.
540 (epg-status-IMPORTED): New function.
541 (epg-status-IMPORT_OK): New function.
542 (epg-status-IMPORT_PROBLEM): New function.
543 (epg-start-import-keys): Don't use a temporary output file.
544 (epg-start-receive-keys): New function.
545 (epg-import-keys-from-server): New function.
546 (epg-receive-keys): Alias to epg-import-keys-from-server.
548 2006-05-01 Daiki Ueno <ueno@unixuser.org>
550 * epg.el (epg-start): Signal an error if the process of CONTEXT is
551 already running for other operations.
552 (epg-flush): Abolished.
553 (epg-start-generate-key): New function.
554 (epg-generate-key-from-file): New function.
555 (epg-generate-key-from-string): New function.
556 (epg-status-KEY_CREATED): New function.
557 (epg-status-KEY_NOT_CREATED): New function.
558 (epg-new-signature-type-alist): New variable.
559 (epg-make-new-signature): New object epg-new-signature.
560 (epg-status-SIG_CREATED): Set epg-new-signature object.
561 (epg-new-signature-to-string): New function.
562 (epg-make-signature): Added slots for signature class and version.
563 (epg-start-sign): Fixed rule of the MODE argument.
565 2006-04-30 Daiki Ueno <ueno@unixuser.org>
567 * epa.el (epa-delete-keys): Support deletion of secret keys.
569 * pgg-epg.el (pgg-epg-decrypt-region): Convert line endings of the
572 * epg.el (epg-read-output): Don't convert line endings of the
574 (epg-cancel): Set 'error result.
576 2006-04-29 Daiki Ueno <ueno@unixuser.org>
578 * epg.el (epg-make-signature): Removed user-id; added
579 creation-time, expiration-time, pubkey-algorithm,
581 (epg-process-sentinel): Abolished.
582 (epg-signature-to-string): Decode DN.
583 (epg-list-keys): Cache user-id in epg-user-id-alist.
584 (epg-make-user-id): Renamed name -> string.
586 2006-04-29 Daiki Ueno <ueno@unixuser.org>
588 * epg.el (epg-status-ERRSIG): New function.
589 (epg-verify-file): Signal an error if we encounter ERRSIG status.
590 (epg-verify-string): Ditto.
592 2006-04-28 Daiki Ueno <ueno@unixuser.org>
594 * epg.el: Added typecheck to accessors to objects.
596 2006-04-26 Daiki Ueno <ueno@unixuser.org>
598 * epg.el (epg-status-GET_HIDDEN): Pass epg-context as the first
599 argument of passphrase-callback.
600 (epg-status-PROGRESS): Ditto.
602 2006-04-26 Daiki Ueno <ueno@unixuser.org>
604 * epa.el (epa-select-keys): Don't set inhibit-quit when
605 recursive-edit is called.
606 (epg-cancel): New function.
608 2006-04-25 Daiki Ueno <ueno@unixuser.org>
610 * epg.el (epg-process-sentinel): New function; set 'error if gpg
611 process exited abnormally, but we have not received an error
613 (epg-sign-file): Signal an error only when a signature is not
615 (epg-sign-string): Ditto.
616 (epg-encrypt-file): Signal an error if SIGN is specified and
617 signature is not created.
618 (epg-encrypt-string): Ditto.
620 2006-04-22 Daiki Ueno <ueno@unixuser.org>
622 * epa.el (epa-key-widget-value-create): Decode DN.
623 (epa-list-keys): Add the PROTOCOL argument.
624 (epa-select-keys): Require CONTEXT as the first argument.
626 * epg.el (epg-gpgsm-program): New user option.
627 (epg-dn-type-alist): New variable.
628 (epg-start): Don't specify --command-fd if protocol is CMS.
629 (epg-list-keys): Require CONTEXT as the first argument.
630 (epg-dn-from-string): New function.
631 (epg-decode-dn): New function.
633 2006-04-21 Daiki Ueno <ueno@unixuser.org>
635 * epa.el (epa-sign-keys): New command.
637 * epg.el (epg-start-sign-keys): New function.
638 (epg-sign-keys): New function.
639 (epg-status-GET_HIDDEN): Enable local quit.
640 (epg-status-GET_BOOL): Ditto.
641 (epg-status-GET_LINE): Ditto.
643 2006-04-20 Daiki Ueno <ueno@unixuser.org>
645 * epa.el (epa-list-keys-1): Add 'epa-list-keys property to keylist
648 2006-04-20 Daiki Ueno <ueno@unixuser.org>
650 * pgg-epg.el (pgg-epg-secret-key-id-list): New variable.
651 (pgg-epg-passphrase-callback): New function.
653 * epa.el (epa-select-keys): Added "Cancel" button.
655 2006-04-20 Daiki Ueno <ueno@unixuser.org>
657 * epg.el (epg-signature-to-string): New function.
659 2006-04-20 Daiki Ueno <ueno@unixuser.org>
661 * epa-file.el (epa-file-write-region): RECIPIENTS is now a list of
663 * epa-dired.el (epa-dired-do-encrypt): RECIPIENTS is now a list of
666 * epa.el (epa-select-keys): Added MODE argument.
667 (epa-encrypt-file): RECIPIENTS is now a list of key objects.
669 * epg.el (epg-status-SIG_CREATED): New function.
670 (epg-start-sign): epg-context-signers is now a list of key objects.
671 (epg-start-encrypt): RECIPIENTS is now a list of key objects.
673 2006-04-19 Daiki Ueno <ueno@unixuser.org>
675 * epa.el (epa-verify-file): Show results in minibuffer.
676 * epg.el (epg-debug-buffer): New variable.
677 (epg-flush): New function.
679 2006-04-18 Daiki Ueno <ueno@unixuser.org>
681 * epa.el (epa-export-keys): New command.
682 * epg.el (epg-start-export-keys): Accept a list of epg-key object
685 2006-04-18 Daiki Ueno <ueno@unixuser.org>
687 * epa.el (epa-keys-mode-map): Bind epa-list-keys; epa-import-key.
688 (epa-import-key): New command.
690 * epg.el (epg-delete-problem-alist): New constant.
691 (epg-status-DELETE_PROBLEM): New function.
692 (epg-start-delete-key): New function.
693 (epg-delete-key): New function.
694 (epg-wait-for-completion): Add the NO-EOF argument.
696 2006-04-18 Daiki Ueno <ueno@unixuser.org>
698 * epg.el (epg-start): Insert the command-line arguments to the
700 (epg-start-encrypt): Wait for BEGIN_ENCRYPTION.
701 (epg-start-delete-key): New function.
702 (epg-delete-key): New function.
704 * epa.el (epa-key): New widget.
705 (epa-key-widget-action): New function.
706 (epa-key-widget-value-create): New function.
707 (epa-key-widget-button-face-get): New function.
708 (epa-key-widget-help-echo): New function.
710 2006-04-17 Daiki Ueno <ueno@unixuser.org>
712 * epa-file.el (epa-file-write-region): Check if START is a string.
714 2006-04-17 Daiki Ueno <ueno@unixuser.org>
716 * epa-file.el: Rewritten with file-name-handler.
717 (epa-file-handler): New variable.
718 (epa-file-enable): New command.
719 (epa-file-disable): New command.
721 * epa-setup.el: Call epa-file-enable.
723 2006-04-17 Daiki Ueno <ueno@unixuser.org>
725 * epa-file.el (epa-passphrase): New variable.
726 (epa-file-passphrase-callback-function): New function.
727 (epa-find-file): Reset buffer-undo-list; set
728 buffer-file-coding-system to last-coding-system-used after
731 2006-04-17 Daiki Ueno <ueno@unixuser.org>
733 * epa-file.el (epa-write-file): Try to write region to "/" to get
734 last-coding-system-used to be set.
736 2006-04-17 Daiki Ueno <ueno@unixuser.org>
738 * epa-file.el: New implementation of epf.el.
742 2006-04-17 Daiki Ueno <ueno@unixuser.org>
744 * epa.el (epa-verify-file): Display verify result.
746 * epg.el (epg-invalid-recipients-alist): New variable.
747 (epg-status-INV_RECP): New function.
748 (epg-status-NO_RECP): New function.
750 * epa.el (epa-keys-mode-map): Bind epa-decrypt-file,
751 epa-verify-file, epa-sign-file, and epa-encrypt-file.
752 (epa-decrypt-file): New function imported from epa-dired.el.
753 (epa-verify-file): New function imported from epa-dired.el.
754 (epa-sign-file): New function imported from epa-dired.el.
755 (epa-encrypt-file): New function imported from epa-dired.el.
757 2006-04-16 Daiki Ueno <ueno@unixuser.org>
759 * epa.el (epa-select-keys): Renamed from epa-ask-keys; use
761 * epa-dired.el (epa-dired-encrypt-file): Use epa-select-keys.
763 2006-04-16 Daiki Ueno <ueno@unixuser.org>
765 * epa-setup.el: New file.
766 * epa-dired.el: New file.
768 * epg.el (epg-colons-pub-spec): Abolished.
769 (epg-colons-sec-spec): Abolished.
770 (epg-colons-uid-spec): Abolished.
771 (epg-colons-fpr-spec): Abolished.
772 (epg-key-validity-alist): New variable.
773 (epg-key-capablity-alist): New variable.
774 (epg-make-key): New object epg-key.
775 (epg-make-sub-key): New object epg-sub-key.
776 (epg-make-user-id): New object epg-user-id.
777 (epg-list-keys-1): Renamed from epg-list-keys.
778 (epg-list-keys): Rewritten.
780 2006-04-15 Daiki Ueno <ueno@unixuser.org>
782 * epg.el (epg-list-keys): Make the NAME argument optional.
784 2006-04-13 Daiki Ueno <ueno@unixuser.org>
786 * epa.el: Added header.
788 * epg.el (epg-list-keys): Specify --with-fingerprint.
789 (epg-colons-fpr-spec): New variable.
790 (epg-colons-pub-spec): Renamed trust -> validity and ownertrust ->
792 (epg-colons-sec-spec): Ditto.
793 (epg-colons-uid-spec): Renamed trust -> validity.
795 2006-04-13 Daiki Ueno <ueno@unixuser.org>
799 * epg.el (epg-cipher-algorithm-alist): New constant.
800 (epg-pubkey-algorithm-alist): New constant.
801 (epg-digest-algorithm-alist): New constant.
802 (epg-compress-algorithm-alist): New constant.
803 (epg-configuration): New function.
804 (epg-start): Don't specify --yes.
806 2006-04-13 Daiki Ueno <ueno@unixuser.org>
808 * epg.el (epg-make-data-from-file): New function.
809 (epg-make-data-from-string): New function.
810 (epg-data-file): New function.
811 (epg-data-string): New function.
812 (epg-start-decrypt): Get a cipher text from a data object.
813 (epg-delete-output-file): New function.
814 (epg-decrypt-file): Add the 3rd argument PLAIN to specify where
816 (epg-start-verify): Get a signature and signed-text from a data
818 (epg-verify-file): Added the 3rd argument PLAIN to specify where
819 the output goes; return the plain text if PLAIN is nil.
820 (epg-verify-string): Return the plain text.
821 (epg-start-sign): Get a plain text from a data object.
822 (epg-sign-file): Added the 3rd argument SIGNATURE to specify where
824 (epg-start-encrypt): Get a plain text from a data object.
825 (epg-encrypt-file): Added the 4th argument CIPHER to specify where
827 (epg-start-import-keys): Get keys from a data object.
828 (epg-import-keys-1): New function.
829 (epg-import-keys-from-file): Use it.
830 (epg-import-keys-from-string): Use it.
832 2006-04-12 Daiki Ueno <ueno@unixuser.org>
834 * epf.el: Renamed from epg-file.el.
836 2006-04-12 Daiki Ueno <ueno@unixuser.org>
838 * epg.el (epg-status-GET_BOOL): New function.
839 (epg-status-GET_LINE): New function.
840 (epg-prompt-alist): New variable, to be filled.
842 * pgg-epg.el (mml2015-gpg-extract-signature-details): New function.
843 * epg.el (epg-signature-fingerprint): New function.
844 (epg-signature-set-fingerprint): New function.
845 (epg-status-VALIDSIG): New function.
847 * epg.el (epg-reset): Don't reset result.
848 (epg-start-decrypt): Reset result before epg-start.
849 (epg-start-verify): Ditto.
850 (epg-start-sign): Ditto.
851 (epg-start-encrypt): Ditto.
852 (epg-start-export-keys): Ditto.
853 (epg-start-import-keys): Ditto.
855 * Makefile.am (EXTRA_DIST): Added pgg-epg.el.
856 * pgg-epg.el: New file.
858 * epg.el (epg-start-export-keys): New function.
859 (epg-export-keys): New function.
860 (epg-start-import-keys): New function.
861 (epg-import-keys): New function.
862 (epg-verify-file): New function.
864 * epg-file.el (epg-file-write-region): Support public key encryption.
866 * epg.el (epg-passphrase-callback-function): Always display key-id.