1 2007-01-29 Daiki Ueno <ueno@unixuser.org>
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.
9 2007-01-05 Daiki Ueno <ueno@unixuser.org>
11 * epg-pgp50i.el: Removed.
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
17 * epg.el (epg--status-VALIDSIG): Don't set expiration-time if it
19 (epg--make-sub-key-1): Ditto.
20 (epg--decode-hexstring): "\\x" -> "\\\\x".
21 (epg--decode-quotedstring): Ditto.
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.
28 2007-01-04 Daiki Ueno <ueno@unixuser.org>
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.
36 * configure.ac: Don't exit if GnuPG (>= 1.4.3) is unavailable.
38 * epg.el (epg-signature-to-string): Print creation-time and used
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.
44 2006-12-31 Daiki Ueno <ueno@unixuser.org>
46 * epa.el (epa-mail-modes): New user option.
47 (epa--mail-mode-p): New function.
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.
56 2006-12-31 Daiki Ueno <ueno@unixuser.org>
58 * epa.el (epa--derived-mode-p): New alias.
60 (epa-encrypt): Use it.
62 2006-12-31 Daiki Ueno <ueno@unixuser.org>
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.
74 2006-12-29 Daiki Ueno <ueno@unixuser.org>
76 * EasyPG: Version 0.0.9 released.
77 * epg-config.el (epg-version-number): Bump up.
78 * configure.ac: Bump up version.
80 2006-12-28 Daiki Ueno <ueno@unixuser.org>
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.
86 2006-12-26 Daiki Ueno <ueno@unixuser.org>
88 * epg-config.el (epg-passphrase-coding-system): Default to nil.
90 2006-12-20 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
92 * epa.el (epa--format-fingerprint-1): New function.
93 (epa--format-fingerprint): Ditto.
94 (epa--show-key): Use it.
96 2006-12-20 Daiki Ueno <ueno@unixuser.org>
98 * epa-file.el (epa-file-write-region): Don't attempt to write the
99 region to "/" to determine safe coding-system.
101 * epa.el (epa-list-keys): Abolished PROTOCOL arg.
102 (epa-sign-file): Save the output to *.p7s or *.p7m file if
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
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.
115 2006-12-19 Daiki Ueno <ueno@unixuser.org>
117 * epg.el (epg-export-keys-to-file): Fixed a typo.
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
124 (epa-import-keys-region): New command.
125 (epa-insert-keys): New command.
126 (epa--insert-keys): Renamed from epa-insert-keys.
128 2006-12-11 Daiki Ueno <ueno@unixuser.org>
130 * pgg-epg.el (pgg-epg-decrypt-region): Don't call
131 decode-coding-string if it is not bound.
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.
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.
144 * epg.el (epg--encode-coding-string): New alias.
145 (epg--status-GET_HIDDEN): Use it.
147 2006-11-29 Daiki Ueno <ueno@unixuser.org>
149 * EasyPG: Version 0.0.8 released.
150 * epg-config.el (epg-version-number): Bump up.
151 * configure.ac: Bump up version.
153 2006-11-20 Andreas Seltenreich <uwi7@rz.uni-karlsruhe.de>
155 * epa-file.el (epa-file-encrypt-to): New file local variable.
156 (epa-file-write-region): Specify recipients by epa-file-encrypt-to.
158 2006-11-26 Daiki Ueno <ueno@unixuser.org>
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.
165 2006-11-25 Daiki Ueno <ueno@unixuser.org>
167 * epa.el (epa-keys-mode): Don't call widget-setup.
168 (epa-list-keys): Call widget-setup here.
169 (epa-select-keys): Ditto.
171 2006-11-24 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
173 * epg.el (epg-delete-keys): Remove redundant argument for `error'
174 and fix a close parenthesis.
176 2006-11-24 Daiki Ueno <ueno@unixuser.org>
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>
182 2006-11-23 Daiki Ueno <ueno@unixuser.org>
184 * epa.el (epa-sign-region): Query signature type at a time.
186 2006-11-22 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
188 * epg.el (epg-context-set-passphrase-callback): Add optional
190 (epg-context-set-progress-callback): Ditto.
192 2006-11-14 Daiki Ueno <ueno@unixuser.org>
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>.
198 * epg.el (epg--start): Don't specify --enable-progress-filter for
200 (epg--status-PROGRESS): Check if progress-callback is set.
202 2006-11-12 Daiki Ueno <ueno@unixuser.org>
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
211 * epa.el (epa-decrypt-file): Expand file name.
212 (epa-verify-file): Ditto.
213 (epa-import-keys): Ditto.
215 2006-11-12 Daiki Ueno <ueno@unixuser.org>
217 * epg.el (epg-delete-keys): Decode delete-problem.
219 * epa.el (epa-popup-info-window): Turn on by default.
220 (epa-display-info): Split selected window instead of pop-to-buffer.
222 2006-11-12 Daiki Ueno <ueno@unixuser.org>
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.
233 * epg.el (epg-start-sign-keys): Make it obsolete; signing a key is
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.
241 * epa.el (epa-keys-mode-map): Don't bind epa-sign-keys.
242 (epa-sign-keys): Make it obsolete.
244 2006-11-11 Daiki Ueno <ueno@unixuser.org>
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
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.
258 2006-10-29 Daiki Ueno <ueno@unixuser.org>
260 * EasyPG: Version 0.0.7 released.
261 * epg-config.el (epg-version-number): Bump up.
262 * configure.ac: Bump up version.
264 2006-10-29 Daiki Ueno <ueno@unixuser.org>
267 (epa-file-cache-passphrase-for-symmetric-encryption): New user
270 2006-10-12 Daiki Ueno <ueno@unixuser.org>
272 * epg.el (epg-start-verify): Fixed a clearsign verification bug.
273 Reported by Hirohisa Yamaguchi <umq@ueo.co.jp>.
275 2006-09-29 Daiki Ueno <ueno@unixuser.org>
277 * EasyPG: Version 0.0.6 released.
278 * epg.el (epg-version-number): Bump up.
279 * configure.ac: Bump up version.
281 2006-09-29 Daiki Ueno <ueno@unixuser.org>
283 * epa.el (epa-verify-cleartext-in-region): Renamed from
284 epa-verify-armor-in-region.
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.
295 2006-09-27 Daiki Ueno <ueno@unixuser.org>
297 * epa-file.el (epa-file-insert-file-contents): Set progress callback.
298 (epa-file-write-region): Ditto.
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.
308 * epg.el (epg-progress-callback-function): Removed.
310 2006-09-24 Daiki Ueno <ueno@unixuser.org>
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.
317 2006-09-23 Daiki Ueno <ueno@unixuser.org>
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.
326 2006-09-23 Daiki Ueno <ueno@unixuser.org>
328 * epg.el (epg-make-context): Don't set progress-callback by
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
335 2006-09-15 Daiki Ueno <ueno@unixuser.org>
337 * epg.el (epg-progress-callback-function): Show the percentage.
339 2006-09-15 Juliusz Chroboczek <Juliusz.Chroboczek@pps.jussieu.fr>
341 * pgg-epg.el (mml2015-gpg-extract-signature-details): Fixed a typo.
343 2006-09-13 Daiki Ueno <ueno@unixuser.org>
345 * epg-config.el (epg-passphrase-coding-system): Renamed from
346 epg-locale-coding-system.
348 2006-09-11 Daiki Ueno <ueno@unixuser.org>
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.
354 * epg.el (epg--start): Specify --enable-progress-filter in
356 (epg-progress-callback-function): Remove a couple of %%'s.
358 2006-09-05 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
360 * epg-config.el (epg-configuration): Fixed the last change;
361 collect configuration other than group and algorithm.
363 2006-09-05 Daiki Ueno <ueno@unixuser.org>
365 * epg-config.el (epg-debug): Moved from epg.el.
366 (epg-configuration): Parse group configuration.
367 (epg-expand-group): New function.
369 2006-09-04 Daiki Ueno <ueno@unixuser.org>
371 * EasyPG: Version 0.0.5 released.
372 * epg.el (epg-version-number): Bump up.
373 * configure.ac: Bump up version.
375 2006-09-04 Daiki Ueno <ueno@unixuser.org>
377 * epg-config.el (epg-locale-coding-system): New user option.
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.
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.
389 2006-09-03 Daiki Ueno <ueno@unixuser.org>
391 * epg-config.el: New file; moved GnuPG configuration check from
394 2006-09-02 Daiki Ueno <ueno@unixuser.org>
396 * epg.el (epg-check-configuration): New function.
397 (epg-gpg-home-directory): New user option.
399 * pgg-epg.el (pgg-epg-lookup-key): New function.
401 2006-07-29 Daiki Ueno <ueno@unixuser.org>
403 * EasyPG: Version 0.0.4 released.
404 * epg.el (epg-version-number): Bump up.
405 * configure.ac: Bump up version.
407 2006-07-29 Daiki Ueno <ueno@unixuser.org>
409 * acinclude.m4 (AC_CHECK_GPG): Run $3 if there is no gpg executable.
411 2006-07-28 Daiki Ueno <ueno@unixuser.org>
413 * epg.el (epg-start-encrypt): Extract primary key ID from
415 Thanks to Steve Youngs <steve@sxemacs.org>
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>
421 2006-07-18 Daiki Ueno <ueno@unixuser.org>
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.
431 * epg.el (epg--process-filter): Don't save-excursion during
434 2006-07-18 Daiki Ueno <ueno@unixuser.org>
436 * acinclude.m4 (AC_CHECK_GPG): Renamed from AC_PATH_GPG.
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.
443 2006-07-14 Daiki Ueno <ueno@unixuser.org>
445 * epg-pgp50i.el: New file.
447 2006-07-13 Daiki Ueno <ueno@unixuser.org>
449 * acinclude.m4 (AC_PATH_GPG): New macro.
450 * configure.ac: Check gpg version.
451 Suggested by Max Froumentin <max@lapin-bleu.net>
453 2006-07-10 Daiki Ueno <ueno@unixuser.org>
455 * epg.el (epg--status-ERRSIG): Don't remove the last verify-result.
456 (epg-signature-to-string): Remove a trailing whitespace.
458 * epa.el (epa-keys-mode-map): Bind return to epa-toggle-mark.
459 (epa-toggle-mark): New command.
461 2006-07-04 Daiki Ueno <ueno@unixuser.org>
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>
467 2006-07-01 Daiki Ueno <ueno@unixuser.org>
469 * epa.el (epa-select-keys): If SECRET is specified, select a
470 primary secret key by default.
472 2006-06-29 Daiki Ueno <ueno@unixuser.org>
474 * EasyPG: Version 0.0.3 released.
475 * epg.el (epg-version-number): Bump up.
476 * configure.ac: Bump up version.
478 2006-06-12 Daiki Ueno <ueno@unixuser.org>
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>
484 2006-06-01 Daiki Ueno <ueno@unixuser.org>
486 * epa-file.el (epa-file-insert-file-contents): Support partial read.
488 2006-05-30 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
490 * epa-file.el (epa-file-write-region): Encode the plain text with
491 coding-system-for-write.
493 2006-05-30 Daiki Ueno <ueno@unixuser.org>
495 * epa-file.el (epa-file-insert-file-contents):
496 Decode the decrypted text with coding-system-for-read.
498 2006-05-29 Daiki Ueno <ueno@unixuser.org>
500 * EasyPG: Version 0.0.2 released.
501 * epg.el (epg-version-number): Bump up.
502 * configure.ac: Bump up version.
504 2006-05-29 Daiki Ueno <ueno@unixuser.org>
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.
511 2006-05-28 Daiki Ueno <ueno@unixuser.org>
513 * epg.el (epg-start-import-keys): Don't specify filename if keys
516 2006-05-27 Daiki Ueno <ueno@unixuser.org>
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.
523 2006-05-26 Daiki Ueno <ueno@unixuser.org>
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.
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.
539 * epg.el (epg-make-context): New slot "operation".
540 (epg-passphrase-callback-function): Confirm passphrase when
541 performing symmetric encryption.
543 2006-05-25 Daiki Ueno <ueno@unixuser.org>
545 * epa.el (epa-decrypt-file): Display verify result if the message
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.
554 2006-05-11 Daiki Ueno <ueno@unixuser.org>
556 * epa.el (epa-armor): New user option.
557 (epa-textmode): New user option.
559 2006-05-02 Daiki Ueno <ueno@unixuser.org>
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.
570 2006-05-01 Daiki Ueno <ueno@unixuser.org>
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.
584 2006-05-01 Daiki Ueno <ueno@unixuser.org>
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.
601 2006-04-30 Daiki Ueno <ueno@unixuser.org>
603 * epa.el (epa-delete-keys): Support deletion of secret keys.
605 * pgg-epg.el (pgg-epg-decrypt-region): Convert line endings of the
608 * epg.el (epg-read-output): Don't convert line endings of the
610 (epg-cancel): Set 'error result.
612 2006-04-29 Daiki Ueno <ueno@unixuser.org>
614 * epg.el (epg-make-signature): Removed user-id; added
615 creation-time, expiration-time, pubkey-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.
622 2006-04-29 Daiki Ueno <ueno@unixuser.org>
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.
628 2006-04-28 Daiki Ueno <ueno@unixuser.org>
630 * epg.el: Added typecheck to accessors to objects.
632 2006-04-26 Daiki Ueno <ueno@unixuser.org>
634 * epg.el (epg-status-GET_HIDDEN): Pass epg-context as the first
635 argument of passphrase-callback.
636 (epg-status-PROGRESS): Ditto.
638 2006-04-26 Daiki Ueno <ueno@unixuser.org>
640 * epa.el (epa-select-keys): Don't set inhibit-quit when
641 recursive-edit is called.
642 (epg-cancel): New function.
644 2006-04-25 Daiki Ueno <ueno@unixuser.org>
646 * epg.el (epg-process-sentinel): New function; set 'error if gpg
647 process exited abnormally, but we have not received an error
649 (epg-sign-file): Signal an error only when a signature is not
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.
656 2006-04-22 Daiki Ueno <ueno@unixuser.org>
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.
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.
669 2006-04-21 Daiki Ueno <ueno@unixuser.org>
671 * epa.el (epa-sign-keys): New command.
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.
679 2006-04-20 Daiki Ueno <ueno@unixuser.org>
681 * epa.el (epa-list-keys-1): Add 'epa-list-keys property to keylist
684 2006-04-20 Daiki Ueno <ueno@unixuser.org>
686 * pgg-epg.el (pgg-epg-secret-key-id-list): New variable.
687 (pgg-epg-passphrase-callback): New function.
689 * epa.el (epa-select-keys): Added "Cancel" button.
691 2006-04-20 Daiki Ueno <ueno@unixuser.org>
693 * epg.el (epg-signature-to-string): New function.
695 2006-04-20 Daiki Ueno <ueno@unixuser.org>
697 * epa-file.el (epa-file-write-region): RECIPIENTS is now a list of
699 * epa-dired.el (epa-dired-do-encrypt): RECIPIENTS is now a list of
702 * epa.el (epa-select-keys): Added MODE argument.
703 (epa-encrypt-file): RECIPIENTS is now a list of key objects.
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.
709 2006-04-19 Daiki Ueno <ueno@unixuser.org>
711 * epa.el (epa-verify-file): Show results in minibuffer.
712 * epg.el (epg-debug-buffer): New variable.
713 (epg-flush): New function.
715 2006-04-18 Daiki Ueno <ueno@unixuser.org>
717 * epa.el (epa-export-keys): New command.
718 * epg.el (epg-start-export-keys): Accept a list of epg-key object
721 2006-04-18 Daiki Ueno <ueno@unixuser.org>
723 * epa.el (epa-keys-mode-map): Bind epa-list-keys; epa-import-key.
724 (epa-import-key): New command.
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.
732 2006-04-18 Daiki Ueno <ueno@unixuser.org>
734 * epg.el (epg-start): Insert the command-line arguments to the
736 (epg-start-encrypt): Wait for BEGIN_ENCRYPTION.
737 (epg-start-delete-key): New function.
738 (epg-delete-key): New function.
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.
746 2006-04-17 Daiki Ueno <ueno@unixuser.org>
748 * epa-file.el (epa-file-write-region): Check if START is a string.
750 2006-04-17 Daiki Ueno <ueno@unixuser.org>
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.
757 * epa-setup.el: Call epa-file-enable.
759 2006-04-17 Daiki Ueno <ueno@unixuser.org>
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
767 2006-04-17 Daiki Ueno <ueno@unixuser.org>
769 * epa-file.el (epa-write-file): Try to write region to "/" to get
770 last-coding-system-used to be set.
772 2006-04-17 Daiki Ueno <ueno@unixuser.org>
774 * epa-file.el: New implementation of epf.el.
778 2006-04-17 Daiki Ueno <ueno@unixuser.org>
780 * epa.el (epa-verify-file): Display verify result.
782 * epg.el (epg-invalid-recipients-alist): New variable.
783 (epg-status-INV_RECP): New function.
784 (epg-status-NO_RECP): New function.
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.
793 2006-04-16 Daiki Ueno <ueno@unixuser.org>
795 * epa.el (epa-select-keys): Renamed from epa-ask-keys; use
797 * epa-dired.el (epa-dired-encrypt-file): Use epa-select-keys.
799 2006-04-16 Daiki Ueno <ueno@unixuser.org>
801 * epa-setup.el: New file.
802 * epa-dired.el: New file.
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.
816 2006-04-15 Daiki Ueno <ueno@unixuser.org>
818 * epg.el (epg-list-keys): Make the NAME argument optional.
820 2006-04-13 Daiki Ueno <ueno@unixuser.org>
822 * epa.el: Added header.
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 ->
828 (epg-colons-sec-spec): Ditto.
829 (epg-colons-uid-spec): Renamed trust -> validity.
831 2006-04-13 Daiki Ueno <ueno@unixuser.org>
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.
842 2006-04-13 Daiki Ueno <ueno@unixuser.org>
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
852 (epg-start-verify): Get a signature and signed-text from a data
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
860 (epg-start-encrypt): Get a plain text from a data object.
861 (epg-encrypt-file): Added the 4th argument CIPHER to specify where
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.
868 2006-04-12 Daiki Ueno <ueno@unixuser.org>
870 * epf.el: Renamed from epg-file.el.
872 2006-04-12 Daiki Ueno <ueno@unixuser.org>
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.
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.
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.
891 * Makefile.am (EXTRA_DIST): Added pgg-epg.el.
892 * pgg-epg.el: New file.
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.
900 * epg-file.el (epg-file-write-region): Support public key encryption.
902 * epg.el (epg-passphrase-callback-function): Always display key-id.