1 2006-09-05 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
3 * epg-config.el (epg-configuration): Fixed the last change;
4 collect configuration other than group and algorithm.
6 2006-09-05 Daiki Ueno <ueno@unixuser.org>
8 * epg-config.el (epg-debug): Moved from epg.el.
9 (epg-configuration): Parse group configuration.
10 (epg-expand-group): New function.
12 2006-09-04 Daiki Ueno <ueno@unixuser.org>
14 * EasyPG: Version 0.0.5 released.
15 * epg.el (epg-version-number): Bump up.
16 * configure.ac: Bump up version.
18 2006-09-04 Daiki Ueno <ueno@unixuser.org>
20 * epg-config.el (epg-locale-coding-system): New user option.
22 * epg.el (epg--list-keys-1): Respect epg-gpg-home-directory.
23 (epg--clear-string): New function.
24 (epg--status-GET_HIDDEN): Encode passphrase with
25 terminal-coding-system.
27 * epg-config.el (epg-gpg-minimum-version): New constant.
28 (epg-config--parse-version): New function.
29 (epg-config--compare-version): New function.
30 (epg-configuration): Respect epg-gpg-home-directory.
32 2006-09-03 Daiki Ueno <ueno@unixuser.org>
34 * epg-config.el: New file; moved GnuPG configuration check from
37 2006-09-02 Daiki Ueno <ueno@unixuser.org>
39 * epg.el (epg-check-configuration): New function.
40 (epg-gpg-home-directory): New user option.
42 * pgg-epg.el (pgg-epg-lookup-key): New function.
44 2006-07-29 Daiki Ueno <ueno@unixuser.org>
46 * EasyPG: Version 0.0.4 released.
47 * epg.el (epg-version-number): Bump up.
48 * configure.ac: Bump up version.
50 2006-07-29 Daiki Ueno <ueno@unixuser.org>
52 * acinclude.m4 (AC_CHECK_GPG): Run $3 if there is no gpg executable.
54 2006-07-28 Daiki Ueno <ueno@unixuser.org>
56 * epg.el (epg-start-encrypt): Extract primary key ID from
58 Thanks to Steve Youngs <steve@sxemacs.org>
60 * pgg-epg.el (pgg-epg-encrypt-region): Fixed a bug; it didn't
61 give CONTEXT to epg-list-keys.
62 Thanks to Steve Youngs <steve@sxemacs.org>
64 2006-07-18 Daiki Ueno <ueno@unixuser.org>
66 * epg-pgp50i.el (epg-pgp50i--process-filter): Use
67 epg-process-filter-running instead of epg-pgp50i-status; Don't
68 save-excursion during handler execution.
69 (epg-pgp50i--read-line): Renamed from epg-pgp50i--wait-for-line;
70 don't allow process input.
71 (epg-pgp50i--parse-time): New function.
72 (epg-pgp50i--status-BAD_SIGNATURE): New function.
74 * epg.el (epg--process-filter): Don't save-excursion during
77 2006-07-18 Daiki Ueno <ueno@unixuser.org>
79 * acinclude.m4 (AC_CHECK_GPG): Renamed from AC_PATH_GPG.
81 * epg.el (epg-process-filter-running): New variable.
82 (epg--start): Setup epg-process-filter-running.
83 (epg--process-filter): Allow only one status handler to run at a
84 time; update epg-read-point everytime the point changes.
86 2006-07-14 Daiki Ueno <ueno@unixuser.org>
88 * epg-pgp50i.el: New file.
90 2006-07-13 Daiki Ueno <ueno@unixuser.org>
92 * acinclude.m4 (AC_PATH_GPG): New macro.
93 * configure.ac: Check gpg version.
94 Suggested by Max Froumentin <max@lapin-bleu.net>
96 2006-07-10 Daiki Ueno <ueno@unixuser.org>
98 * epg.el (epg--status-ERRSIG): Don't remove the last verify-result.
99 (epg-signature-to-string): Remove a trailing whitespace.
101 * epa.el (epa-keys-mode-map): Bind return to epa-toggle-mark.
102 (epa-toggle-mark): New command.
104 2006-07-04 Daiki Ueno <ueno@unixuser.org>
106 * pgg-epg.el (pgg-epg-sign-region): Select the signing key matched
107 with pgg-default-user-id.
108 Reported by Elias Oltmanns <oltmanns@uni-bonn.de>
110 2006-07-01 Daiki Ueno <ueno@unixuser.org>
112 * epa.el (epa-select-keys): If SECRET is specified, select a
113 primary secret key by default.
115 2006-06-29 Daiki Ueno <ueno@unixuser.org>
117 * EasyPG: Version 0.0.3 released.
118 * epg.el (epg-version-number): Bump up.
119 * configure.ac: Bump up version.
121 2006-06-12 Daiki Ueno <ueno@unixuser.org>
123 * epa-file.el (epa-file-insert-file-contents): Don't move the
124 point to the end of the inserted region.
125 Reported by doug <douglas.bagley@gmail.com>
127 2006-06-01 Daiki Ueno <ueno@unixuser.org>
129 * epa-file.el (epa-file-insert-file-contents): Support partial read.
131 2006-05-30 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
133 * epa-file.el (epa-file-write-region): Encode the plain text with
134 coding-system-for-write.
136 2006-05-30 Daiki Ueno <ueno@unixuser.org>
138 * epa-file.el (epa-file-insert-file-contents):
139 Decode the decrypted text with coding-system-for-read.
141 2006-05-29 Daiki Ueno <ueno@unixuser.org>
143 * EasyPG: Version 0.0.2 released.
144 * epg.el (epg-version-number): Bump up.
145 * configure.ac: Bump up version.
147 2006-05-29 Daiki Ueno <ueno@unixuser.org>
149 * epg.el (epg--time-from-seconds): New function.
150 (epg--status-ERRSIG): Convert seconds from epoch to encoded-time.
151 (epg--status-VALIDSIG): Ditto.
152 (epg--status-KEYEXPIRED): Ditto.
154 2006-05-28 Daiki Ueno <ueno@unixuser.org>
156 * epg.el (epg-start-import-keys): Don't specify filename if keys
159 2006-05-27 Daiki Ueno <ueno@unixuser.org>
161 * epg.el (epg--process-filter): Pass epg-context instead of
162 process to status handlers.
163 (epg--status-NO_PUBKEY): Check if the previous signature's key-id
164 matches with the given key-id.
166 2006-05-26 Daiki Ueno <ueno@unixuser.org>
168 * epg.el (epg--status-NO_PUBKEY): Replace the previous signature's
169 status from 'error to 'no-pubkey.
170 (epg--status-ERRSIG): Just add 'error signature to the verify result.
172 * epa.el (epa-insert-keys): Renamed from epa-list-keys-1; don't
173 disable inhibit-quit here; make text-properties nonsticky.
174 (epa-popup-info-window): New user option.
175 (epa-info-window-height): New user option.
176 (epa-display-verify-result): New function.
177 (epa-decrypt-file): Use it.
178 (epa-verify-file): Use it.
179 (epa-decrypt-region): Use it.
180 (epa-verify-region): Use it.
182 * epg.el (epg-make-context): New slot "operation".
183 (epg-passphrase-callback-function): Confirm passphrase when
184 performing symmetric encryption.
186 2006-05-25 Daiki Ueno <ueno@unixuser.org>
188 * epa.el (epa-decrypt-file): Display verify result if the message
190 (epa-decrypt-region): New command.
191 (epa-verify-region): New command.
192 (epa-decrypt-armor-in-region): New command.
193 (epa-verify-armor-in-region): New command.
194 (epa-sign-region): New command.
195 (epa-encrypt-region): New command.
197 2006-05-11 Daiki Ueno <ueno@unixuser.org>
199 * epa.el (epa-armor): New user option.
200 (epa-textmode): New user option.
202 2006-05-02 Daiki Ueno <ueno@unixuser.org>
204 * epg.el (epg-make-key-signature): New object epg-key-signature.
205 (epg-list-keys): Collect key signatures.
206 (epg-make-sub-key): Renamed secret -> secret-p.
207 (epg-list-keys-postprocess-one-key): Abolished.
208 (epg-list-keys): Reverse all keys, sub-keys, user-ids, and key
209 signatures by itself.
210 (epg-no-data-reason-alist): New constant.
211 (epg-unexpected-reason-alist): New constant.
213 2006-05-01 Daiki Ueno <ueno@unixuser.org>
215 * epg.el (epg-invalid-recipients-reason-alist): Renamed.
216 (epg-delete-problem-reason-alist): Renamed.
217 (epg-import-ok-reason-alist): New constant.
218 (epg-import-problem-reason-alist): New constant.
219 (epg-status-IMPORTED): New function.
220 (epg-status-IMPORT_OK): New function.
221 (epg-status-IMPORT_PROBLEM): New function.
222 (epg-start-import-keys): Don't use a temporary output file.
223 (epg-start-receive-keys): New function.
224 (epg-import-keys-from-server): New function.
225 (epg-receive-keys): Alias to epg-import-keys-from-server.
227 2006-05-01 Daiki Ueno <ueno@unixuser.org>
229 * epg.el (epg-start): Signal an error if the process of CONTEXT is
230 already running for other operations.
231 (epg-flush): Abolished.
232 (epg-start-generate-key): New function.
233 (epg-generate-key-from-file): New function.
234 (epg-generate-key-from-string): New function.
235 (epg-status-KEY_CREATED): New function.
236 (epg-status-KEY_NOT_CREATED): New function.
237 (epg-new-signature-type-alist): New variable.
238 (epg-make-new-signature): New object epg-new-signature.
239 (epg-status-SIG_CREATED): Set epg-new-signature object.
240 (epg-new-signature-to-string): New function.
241 (epg-make-signature): Added slots for signature class and version.
242 (epg-start-sign): Fixed rule of the MODE argument.
244 2006-04-30 Daiki Ueno <ueno@unixuser.org>
246 * epa.el (epa-delete-keys): Support deletion of secret keys.
248 * pgg-epg.el (pgg-epg-decrypt-region): Convert line endings of the
251 * epg.el (epg-read-output): Don't convert line endings of the
253 (epg-cancel): Set 'error result.
255 2006-04-29 Daiki Ueno <ueno@unixuser.org>
257 * epg.el (epg-make-signature): Removed user-id; added
258 creation-time, expiration-time, pubkey-algorithm,
260 (epg-process-sentinel): Abolished.
261 (epg-signature-to-string): Decode DN.
262 (epg-list-keys): Cache user-id in epg-user-id-alist.
263 (epg-make-user-id): Renamed name -> string.
265 2006-04-29 Daiki Ueno <ueno@unixuser.org>
267 * epg.el (epg-status-ERRSIG): New function.
268 (epg-verify-file): Signal an error if we encounter ERRSIG status.
269 (epg-verify-string): Ditto.
271 2006-04-28 Daiki Ueno <ueno@unixuser.org>
273 * epg.el: Added typecheck to accessors to objects.
275 2006-04-26 Daiki Ueno <ueno@unixuser.org>
277 * epg.el (epg-status-GET_HIDDEN): Pass epg-context as the first
278 argument of passphrase-callback.
279 (epg-status-PROGRESS): Ditto.
281 2006-04-26 Daiki Ueno <ueno@unixuser.org>
283 * epa.el (epa-select-keys): Don't set inhibit-quit when
284 recursive-edit is called.
285 (epg-cancel): New function.
287 2006-04-25 Daiki Ueno <ueno@unixuser.org>
289 * epg.el (epg-process-sentinel): New function; set 'error if gpg
290 process exited abnormally, but we have not received an error
292 (epg-sign-file): Signal an error only when a signature is not
294 (epg-sign-string): Ditto.
295 (epg-encrypt-file): Signal an error if SIGN is specified and
296 signature is not created.
297 (epg-encrypt-string): Ditto.
299 2006-04-22 Daiki Ueno <ueno@unixuser.org>
301 * epa.el (epa-key-widget-value-create): Decode DN.
302 (epa-list-keys): Add the PROTOCOL argument.
303 (epa-select-keys): Require CONTEXT as the first argument.
305 * epg.el (epg-gpgsm-program): New user option.
306 (epg-dn-type-alist): New variable.
307 (epg-start): Don't specify --command-fd if protocol is CMS.
308 (epg-list-keys): Require CONTEXT as the first argument.
309 (epg-dn-from-string): New function.
310 (epg-decode-dn): New function.
312 2006-04-21 Daiki Ueno <ueno@unixuser.org>
314 * epa.el (epa-sign-keys): New command.
316 * epg.el (epg-start-sign-keys): New function.
317 (epg-sign-keys): New function.
318 (epg-status-GET_HIDDEN): Enable local quit.
319 (epg-status-GET_BOOL): Ditto.
320 (epg-status-GET_LINE): Ditto.
322 2006-04-20 Daiki Ueno <ueno@unixuser.org>
324 * epa.el (epa-list-keys-1): Add 'epa-list-keys property to keylist
327 2006-04-20 Daiki Ueno <ueno@unixuser.org>
329 * pgg-epg.el (pgg-epg-secret-key-id-list): New variable.
330 (pgg-epg-passphrase-callback): New function.
332 * epa.el (epa-select-keys): Added "Cancel" button.
334 2006-04-20 Daiki Ueno <ueno@unixuser.org>
336 * epg.el (epg-signature-to-string): New function.
338 2006-04-20 Daiki Ueno <ueno@unixuser.org>
340 * epa-file.el (epa-file-write-region): RECIPIENTS is now a list of
342 * epa-dired.el (epa-dired-do-encrypt): RECIPIENTS is now a list of
345 * epa.el (epa-select-keys): Added MODE argument.
346 (epa-encrypt-file): RECIPIENTS is now a list of key objects.
348 * epg.el (epg-status-SIG_CREATED): New function.
349 (epg-start-sign): epg-context-signers is now a list of key objects.
350 (epg-start-encrypt): RECIPIENTS is now a list of key objects.
352 2006-04-19 Daiki Ueno <ueno@unixuser.org>
354 * epa.el (epa-verify-file): Show results in minibuffer.
355 * epg.el (epg-debug-buffer): New variable.
356 (epg-flush): New function.
358 2006-04-18 Daiki Ueno <ueno@unixuser.org>
360 * epa.el (epa-export-keys): New command.
361 * epg.el (epg-start-export-keys): Accept a list of epg-key object
364 2006-04-18 Daiki Ueno <ueno@unixuser.org>
366 * epa.el (epa-keys-mode-map): Bind epa-list-keys; epa-import-key.
367 (epa-import-key): New command.
369 * epg.el (epg-delete-problem-alist): New constant.
370 (epg-status-DELETE_PROBLEM): New function.
371 (epg-start-delete-key): New function.
372 (epg-delete-key): New function.
373 (epg-wait-for-completion): Add the NO-EOF argument.
375 2006-04-18 Daiki Ueno <ueno@unixuser.org>
377 * epg.el (epg-start): Insert the command-line arguments to the
379 (epg-start-encrypt): Wait for BEGIN_ENCRYPTION.
380 (epg-start-delete-key): New function.
381 (epg-delete-key): New function.
383 * epa.el (epa-key): New widget.
384 (epa-key-widget-action): New function.
385 (epa-key-widget-value-create): New function.
386 (epa-key-widget-button-face-get): New function.
387 (epa-key-widget-help-echo): New function.
389 2006-04-17 Daiki Ueno <ueno@unixuser.org>
391 * epa-file.el (epa-file-write-region): Check if START is a string.
393 2006-04-17 Daiki Ueno <ueno@unixuser.org>
395 * epa-file.el: Rewritten with file-name-handler.
396 (epa-file-handler): New variable.
397 (epa-file-enable): New command.
398 (epa-file-disable): New command.
400 * epa-setup.el: Call epa-file-enable.
402 2006-04-17 Daiki Ueno <ueno@unixuser.org>
404 * epa-file.el (epa-passphrase): New variable.
405 (epa-file-passphrase-callback-function): New function.
406 (epa-find-file): Reset buffer-undo-list; set
407 buffer-file-coding-system to last-coding-system-used after
410 2006-04-17 Daiki Ueno <ueno@unixuser.org>
412 * epa-file.el (epa-write-file): Try to write region to "/" to get
413 last-coding-system-used to be set.
415 2006-04-17 Daiki Ueno <ueno@unixuser.org>
417 * epa-file.el: New implementation of epf.el.
421 2006-04-17 Daiki Ueno <ueno@unixuser.org>
423 * epa.el (epa-verify-file): Display verify result.
425 * epg.el (epg-invalid-recipients-alist): New variable.
426 (epg-status-INV_RECP): New function.
427 (epg-status-NO_RECP): New function.
429 * epa.el (epa-keys-mode-map): Bind epa-decrypt-file,
430 epa-verify-file, epa-sign-file, and epa-encrypt-file.
431 (epa-decrypt-file): New function imported from epa-dired.el.
432 (epa-verify-file): New function imported from epa-dired.el.
433 (epa-sign-file): New function imported from epa-dired.el.
434 (epa-encrypt-file): New function imported from epa-dired.el.
436 2006-04-16 Daiki Ueno <ueno@unixuser.org>
438 * epa.el (epa-select-keys): Renamed from epa-ask-keys; use
440 * epa-dired.el (epa-dired-encrypt-file): Use epa-select-keys.
442 2006-04-16 Daiki Ueno <ueno@unixuser.org>
444 * epa-setup.el: New file.
445 * epa-dired.el: New file.
447 * epg.el (epg-colons-pub-spec): Abolished.
448 (epg-colons-sec-spec): Abolished.
449 (epg-colons-uid-spec): Abolished.
450 (epg-colons-fpr-spec): Abolished.
451 (epg-key-validity-alist): New variable.
452 (epg-key-capablity-alist): New variable.
453 (epg-make-key): New object epg-key.
454 (epg-make-sub-key): New object epg-sub-key.
455 (epg-make-user-id): New object epg-user-id.
456 (epg-list-keys-1): Renamed from epg-list-keys.
457 (epg-list-keys): Rewritten.
459 2006-04-15 Daiki Ueno <ueno@unixuser.org>
461 * epg.el (epg-list-keys): Make the NAME argument optional.
463 2006-04-13 Daiki Ueno <ueno@unixuser.org>
465 * epa.el: Added header.
467 * epg.el (epg-list-keys): Specify --with-fingerprint.
468 (epg-colons-fpr-spec): New variable.
469 (epg-colons-pub-spec): Renamed trust -> validity and ownertrust ->
471 (epg-colons-sec-spec): Ditto.
472 (epg-colons-uid-spec): Renamed trust -> validity.
474 2006-04-13 Daiki Ueno <ueno@unixuser.org>
478 * epg.el (epg-cipher-algorithm-alist): New constant.
479 (epg-pubkey-algorithm-alist): New constant.
480 (epg-digest-algorithm-alist): New constant.
481 (epg-compress-algorithm-alist): New constant.
482 (epg-configuration): New function.
483 (epg-start): Don't specify --yes.
485 2006-04-13 Daiki Ueno <ueno@unixuser.org>
487 * epg.el (epg-make-data-from-file): New function.
488 (epg-make-data-from-string): New function.
489 (epg-data-file): New function.
490 (epg-data-string): New function.
491 (epg-start-decrypt): Get a cipher text from a data object.
492 (epg-delete-output-file): New function.
493 (epg-decrypt-file): Add the 3rd argument PLAIN to specify where
495 (epg-start-verify): Get a signature and signed-text from a data
497 (epg-verify-file): Added the 3rd argument PLAIN to specify where
498 the output goes; return the plain text if PLAIN is nil.
499 (epg-verify-string): Return the plain text.
500 (epg-start-sign): Get a plain text from a data object.
501 (epg-sign-file): Added the 3rd argument SIGNATURE to specify where
503 (epg-start-encrypt): Get a plain text from a data object.
504 (epg-encrypt-file): Added the 4th argument CIPHER to specify where
506 (epg-start-import-keys): Get keys from a data object.
507 (epg-import-keys-1): New function.
508 (epg-import-keys-from-file): Use it.
509 (epg-import-keys-from-string): Use it.
511 2006-04-12 Daiki Ueno <ueno@unixuser.org>
513 * epf.el: Renamed from epg-file.el.
515 2006-04-12 Daiki Ueno <ueno@unixuser.org>
517 * epg.el (epg-status-GET_BOOL): New function.
518 (epg-status-GET_LINE): New function.
519 (epg-prompt-alist): New variable, to be filled.
521 * pgg-epg.el (mml2015-gpg-extract-signature-details): New function.
522 * epg.el (epg-signature-fingerprint): New function.
523 (epg-signature-set-fingerprint): New function.
524 (epg-status-VALIDSIG): New function.
526 * epg.el (epg-reset): Don't reset result.
527 (epg-start-decrypt): Reset result before epg-start.
528 (epg-start-verify): Ditto.
529 (epg-start-sign): Ditto.
530 (epg-start-encrypt): Ditto.
531 (epg-start-export-keys): Ditto.
532 (epg-start-import-keys): Ditto.
534 * Makefile.am (EXTRA_DIST): Added pgg-epg.el.
535 * pgg-epg.el: New file.
537 * epg.el (epg-start-export-keys): New function.
538 (epg-export-keys): New function.
539 (epg-start-import-keys): New function.
540 (epg-import-keys): New function.
541 (epg-verify-file): New function.
543 * epg-file.el (epg-file-write-region): Support public key encryption.
545 * epg.el (epg-passphrase-callback-function): Always display key-id.