1 2006-07-10 Daiki Ueno <ueno@unixuser.org>
3 * epg.el (epg--status-ERRSIG): Don't remove the last verify-result.
4 (epg-signature-to-string): Remove a trailing whitespace.
6 * epa.el (epa-keys-mode-map): Bind return to epa-toggle-mark.
7 (epa-toggle-mark): New command.
9 2006-07-04 Daiki Ueno <ueno@unixuser.org>
11 * pgg-epg.el (pgg-epg-sign-region): Select the signing key matched
12 with pgg-default-user-id.
13 Reported by Elias Oltmanns <oltmanns@uni-bonn.de>
15 2006-07-01 Daiki Ueno <ueno@unixuser.org>
17 * epa.el (epa-select-keys): If SECRET is specified, select a
18 primary secret key by default.
20 2006-06-29 Daiki Ueno <ueno@unixuser.org>
22 * EasyPG: Version 0.0.3 released.
23 * epg.el (epg-version-number): Bump up.
24 * configure.ac: Bump up version.
26 2006-06-12 Daiki Ueno <ueno@unixuser.org>
28 * epa-file.el (epa-file-insert-file-contents): Don't move the
29 point to the end of the inserted region.
30 Reported by doug <douglas.bagley@gmail.com>
32 2006-06-01 Daiki Ueno <ueno@unixuser.org>
34 * epa-file.el (epa-file-insert-file-contents): Support partial read.
36 2006-05-30 Hiroya Murata <lapis-lazuli@pop06.odn.ne.jp>
38 * epa-file.el (epa-file-write-region): Encode the plain text with
39 coding-system-for-write.
41 2006-05-30 Daiki Ueno <ueno@unixuser.org>
43 * epa-file.el (epa-file-insert-file-contents):
44 Decode the decrypted text with coding-system-for-read.
46 2006-05-29 Daiki Ueno <ueno@unixuser.org>
48 * EasyPG: Version 0.0.2 released.
49 * epg.el (epg-version-number): Bump up.
50 * configure.ac: Bump up version.
52 2006-05-29 Daiki Ueno <ueno@unixuser.org>
54 * epg.el (epg--time-from-seconds): New function.
55 (epg--status-ERRSIG): Convert seconds from epoch to encoded-time.
56 (epg--status-VALIDSIG): Ditto.
57 (epg--status-KEYEXPIRED): Ditto.
59 2006-05-28 Daiki Ueno <ueno@unixuser.org>
61 * epg.el (epg-start-import-keys): Don't specify filename if keys
64 2006-05-27 Daiki Ueno <ueno@unixuser.org>
66 * epg.el (epg--process-filter): Pass epg-context instead of
67 process to status handlers.
68 (epg--status-NO_PUBKEY): Check if the previous signature's key-id
69 matches with the given key-id.
71 2006-05-26 Daiki Ueno <ueno@unixuser.org>
73 * epg.el (epg--status-NO_PUBKEY): Replace the previous signature's
74 status from 'error to 'no-pubkey.
75 (epg--status-ERRSIG): Just add 'error signature to the verify result.
77 * epa.el (epa-insert-keys): Renamed from epa-list-keys-1; don't
78 disable inhibit-quit here; make text-properties nonsticky.
79 (epa-popup-info-window): New user option.
80 (epa-info-window-height): New user option.
81 (epa-display-verify-result): New function.
82 (epa-decrypt-file): Use it.
83 (epa-verify-file): Use it.
84 (epa-decrypt-region): Use it.
85 (epa-verify-region): Use it.
87 * epg.el (epg-make-context): New slot "operation".
88 (epg-passphrase-callback-function): Confirm passphrase when
89 performing symmetric encryption.
91 2006-05-25 Daiki Ueno <ueno@unixuser.org>
93 * epa.el (epa-decrypt-file): Display verify result if the message
95 (epa-decrypt-region): New command.
96 (epa-verify-region): New command.
97 (epa-decrypt-armor-in-region): New command.
98 (epa-verify-armor-in-region): New command.
99 (epa-sign-region): New command.
100 (epa-encrypt-region): New command.
102 2006-05-11 Daiki Ueno <ueno@unixuser.org>
104 * epa.el (epa-armor): New user option.
105 (epa-textmode): New user option.
107 2006-05-02 Daiki Ueno <ueno@unixuser.org>
109 * epg.el (epg-make-key-signature): New object epg-key-signature.
110 (epg-list-keys): Collect key signatures.
111 (epg-make-sub-key): Renamed secret -> secret-p.
112 (epg-list-keys-postprocess-one-key): Abolished.
113 (epg-list-keys): Reverse all keys, sub-keys, user-ids, and key
114 signatures by itself.
115 (epg-no-data-reason-alist): New constant.
116 (epg-unexpected-reason-alist): New constant.
118 2006-05-01 Daiki Ueno <ueno@unixuser.org>
120 * epg.el (epg-invalid-recipients-reason-alist): Renamed.
121 (epg-delete-problem-reason-alist): Renamed.
122 (epg-import-ok-reason-alist): New constant.
123 (epg-import-problem-reason-alist): New constant.
124 (epg-status-IMPORTED): New function.
125 (epg-status-IMPORT_OK): New function.
126 (epg-status-IMPORT_PROBLEM): New function.
127 (epg-start-import-keys): Don't use a temporary output file.
128 (epg-start-receive-keys): New function.
129 (epg-import-keys-from-server): New function.
130 (epg-receive-keys): Alias to epg-import-keys-from-server.
132 2006-05-01 Daiki Ueno <ueno@unixuser.org>
134 * epg.el (epg-start): Signal an error if the process of CONTEXT is
135 already running for other operations.
136 (epg-flush): Abolished.
137 (epg-start-generate-key): New function.
138 (epg-generate-key-from-file): New function.
139 (epg-generate-key-from-string): New function.
140 (epg-status-KEY_CREATED): New function.
141 (epg-status-KEY_NOT_CREATED): New function.
142 (epg-new-signature-type-alist): New variable.
143 (epg-make-new-signature): New object epg-new-signature.
144 (epg-status-SIG_CREATED): Set epg-new-signature object.
145 (epg-new-signature-to-string): New function.
146 (epg-make-signature): Added slots for signature class and version.
147 (epg-start-sign): Fixed rule of the MODE argument.
149 2006-04-30 Daiki Ueno <ueno@unixuser.org>
151 * epa.el (epa-delete-keys): Support deletion of secret keys.
153 * pgg-epg.el (pgg-epg-decrypt-region): Convert line endings of the
156 * epg.el (epg-read-output): Don't convert line endings of the
158 (epg-cancel): Set 'error result.
160 2006-04-29 Daiki Ueno <ueno@unixuser.org>
162 * epg.el (epg-make-signature): Removed user-id; added
163 creation-time, expiration-time, pubkey-algorithm,
165 (epg-process-sentinel): Abolished.
166 (epg-signature-to-string): Decode DN.
167 (epg-list-keys): Cache user-id in epg-user-id-alist.
168 (epg-make-user-id): Renamed name -> string.
170 2006-04-29 Daiki Ueno <ueno@unixuser.org>
172 * epg.el (epg-status-ERRSIG): New function.
173 (epg-verify-file): Signal an error if we encounter ERRSIG status.
174 (epg-verify-string): Ditto.
176 2006-04-28 Daiki Ueno <ueno@unixuser.org>
178 * epg.el: Added typecheck to accessors to objects.
180 2006-04-26 Daiki Ueno <ueno@unixuser.org>
182 * epg.el (epg-status-GET_HIDDEN): Pass epg-context as the first
183 argument of passphrase-callback.
184 (epg-status-PROGRESS): Ditto.
186 2006-04-26 Daiki Ueno <ueno@unixuser.org>
188 * epa.el (epa-select-keys): Don't set inhibit-quit when
189 recursive-edit is called.
190 (epg-cancel): New function.
192 2006-04-25 Daiki Ueno <ueno@unixuser.org>
194 * epg.el (epg-process-sentinel): New function; set 'error if gpg
195 process exited abnormally, but we have not received an error
197 (epg-sign-file): Signal an error only when a signature is not
199 (epg-sign-string): Ditto.
200 (epg-encrypt-file): Signal an error if SIGN is specified and
201 signature is not created.
202 (epg-encrypt-string): Ditto.
204 2006-04-22 Daiki Ueno <ueno@unixuser.org>
206 * epa.el (epa-key-widget-value-create): Decode DN.
207 (epa-list-keys): Add the PROTOCOL argument.
208 (epa-select-keys): Require CONTEXT as the first argument.
210 * epg.el (epg-gpgsm-program): New user option.
211 (epg-dn-type-alist): New variable.
212 (epg-start): Don't specify --command-fd if protocol is CMS.
213 (epg-list-keys): Require CONTEXT as the first argument.
214 (epg-dn-from-string): New function.
215 (epg-decode-dn): New function.
217 2006-04-21 Daiki Ueno <ueno@unixuser.org>
219 * epa.el (epa-sign-keys): New command.
221 * epg.el (epg-start-sign-keys): New function.
222 (epg-sign-keys): New function.
223 (epg-status-GET_HIDDEN): Enable local quit.
224 (epg-status-GET_BOOL): Ditto.
225 (epg-status-GET_LINE): Ditto.
227 2006-04-20 Daiki Ueno <ueno@unixuser.org>
229 * epa.el (epa-list-keys-1): Add 'epa-list-keys property to keylist
232 2006-04-20 Daiki Ueno <ueno@unixuser.org>
234 * pgg-epg.el (pgg-epg-secret-key-id-list): New variable.
235 (pgg-epg-passphrase-callback): New function.
237 * epa.el (epa-select-keys): Added "Cancel" button.
239 2006-04-20 Daiki Ueno <ueno@unixuser.org>
241 * epg.el (epg-signature-to-string): New function.
243 2006-04-20 Daiki Ueno <ueno@unixuser.org>
245 * epa-file.el (epa-file-write-region): RECIPIENTS is now a list of
247 * epa-dired.el (epa-dired-do-encrypt): RECIPIENTS is now a list of
250 * epa.el (epa-select-keys): Added MODE argument.
251 (epa-encrypt-file): RECIPIENTS is now a list of key objects.
253 * epg.el (epg-status-SIG_CREATED): New function.
254 (epg-start-sign): epg-context-signers is now a list of key objects.
255 (epg-start-encrypt): RECIPIENTS is now a list of key objects.
257 2006-04-19 Daiki Ueno <ueno@unixuser.org>
259 * epa.el (epa-verify-file): Show results in minibuffer.
260 * epg.el (epg-debug-buffer): New variable.
261 (epg-flush): New function.
263 2006-04-18 Daiki Ueno <ueno@unixuser.org>
265 * epa.el (epa-export-keys): New command.
266 * epg.el (epg-start-export-keys): Accept a list of epg-key object
269 2006-04-18 Daiki Ueno <ueno@unixuser.org>
271 * epa.el (epa-keys-mode-map): Bind epa-list-keys; epa-import-key.
272 (epa-import-key): New command.
274 * epg.el (epg-delete-problem-alist): New constant.
275 (epg-status-DELETE_PROBLEM): New function.
276 (epg-start-delete-key): New function.
277 (epg-delete-key): New function.
278 (epg-wait-for-completion): Add the NO-EOF argument.
280 2006-04-18 Daiki Ueno <ueno@unixuser.org>
282 * epg.el (epg-start): Insert the command-line arguments to the
284 (epg-start-encrypt): Wait for BEGIN_ENCRYPTION.
285 (epg-start-delete-key): New function.
286 (epg-delete-key): New function.
288 * epa.el (epa-key): New widget.
289 (epa-key-widget-action): New function.
290 (epa-key-widget-value-create): New function.
291 (epa-key-widget-button-face-get): New function.
292 (epa-key-widget-help-echo): New function.
294 2006-04-17 Daiki Ueno <ueno@unixuser.org>
296 * epa-file.el (epa-file-write-region): Check if START is a string.
298 2006-04-17 Daiki Ueno <ueno@unixuser.org>
300 * epa-file.el: Rewritten with file-name-handler.
301 (epa-file-handler): New variable.
302 (epa-file-enable): New command.
303 (epa-file-disable): New command.
305 * epa-setup.el: Call epa-file-enable.
307 2006-04-17 Daiki Ueno <ueno@unixuser.org>
309 * epa-file.el (epa-passphrase): New variable.
310 (epa-file-passphrase-callback-function): New function.
311 (epa-find-file): Reset buffer-undo-list; set
312 buffer-file-coding-system to last-coding-system-used after
315 2006-04-17 Daiki Ueno <ueno@unixuser.org>
317 * epa-file.el (epa-write-file): Try to write region to "/" to get
318 last-coding-system-used to be set.
320 2006-04-17 Daiki Ueno <ueno@unixuser.org>
322 * epa-file.el: New implementation of epf.el.
326 2006-04-17 Daiki Ueno <ueno@unixuser.org>
328 * epa.el (epa-verify-file): Display verify result.
330 * epg.el (epg-invalid-recipients-alist): New variable.
331 (epg-status-INV_RECP): New function.
332 (epg-status-NO_RECP): New function.
334 * epa.el (epa-keys-mode-map): Bind epa-decrypt-file,
335 epa-verify-file, epa-sign-file, and epa-encrypt-file.
336 (epa-decrypt-file): New function imported from epa-dired.el.
337 (epa-verify-file): New function imported from epa-dired.el.
338 (epa-sign-file): New function imported from epa-dired.el.
339 (epa-encrypt-file): New function imported from epa-dired.el.
341 2006-04-16 Daiki Ueno <ueno@unixuser.org>
343 * epa.el (epa-select-keys): Renamed from epa-ask-keys; use
345 * epa-dired.el (epa-dired-encrypt-file): Use epa-select-keys.
347 2006-04-16 Daiki Ueno <ueno@unixuser.org>
349 * epa-setup.el: New file.
350 * epa-dired.el: New file.
352 * epg.el (epg-colons-pub-spec): Abolished.
353 (epg-colons-sec-spec): Abolished.
354 (epg-colons-uid-spec): Abolished.
355 (epg-colons-fpr-spec): Abolished.
356 (epg-key-validity-alist): New variable.
357 (epg-key-capablity-alist): New variable.
358 (epg-make-key): New object epg-key.
359 (epg-make-sub-key): New object epg-sub-key.
360 (epg-make-user-id): New object epg-user-id.
361 (epg-list-keys-1): Renamed from epg-list-keys.
362 (epg-list-keys): Rewritten.
364 2006-04-15 Daiki Ueno <ueno@unixuser.org>
366 * epg.el (epg-list-keys): Make the NAME argument optional.
368 2006-04-13 Daiki Ueno <ueno@unixuser.org>
370 * epa.el: Added header.
372 * epg.el (epg-list-keys): Specify --with-fingerprint.
373 (epg-colons-fpr-spec): New variable.
374 (epg-colons-pub-spec): Renamed trust -> validity and ownertrust ->
376 (epg-colons-sec-spec): Ditto.
377 (epg-colons-uid-spec): Renamed trust -> validity.
379 2006-04-13 Daiki Ueno <ueno@unixuser.org>
383 * epg.el (epg-cipher-algorithm-alist): New constant.
384 (epg-pubkey-algorithm-alist): New constant.
385 (epg-digest-algorithm-alist): New constant.
386 (epg-compress-algorithm-alist): New constant.
387 (epg-configuration): New function.
388 (epg-start): Don't specify --yes.
390 2006-04-13 Daiki Ueno <ueno@unixuser.org>
392 * epg.el (epg-make-data-from-file): New function.
393 (epg-make-data-from-string): New function.
394 (epg-data-file): New function.
395 (epg-data-string): New function.
396 (epg-start-decrypt): Get a cipher text from a data object.
397 (epg-delete-output-file): New function.
398 (epg-decrypt-file): Add the 3rd argument PLAIN to specify where
400 (epg-start-verify): Get a signature and signed-text from a data
402 (epg-verify-file): Added the 3rd argument PLAIN to specify where
403 the output goes; return the plain text if PLAIN is nil.
404 (epg-verify-string): Return the plain text.
405 (epg-start-sign): Get a plain text from a data object.
406 (epg-sign-file): Added the 3rd argument SIGNATURE to specify where
408 (epg-start-encrypt): Get a plain text from a data object.
409 (epg-encrypt-file): Added the 4th argument CIPHER to specify where
411 (epg-start-import-keys): Get keys from a data object.
412 (epg-import-keys-1): New function.
413 (epg-import-keys-from-file): Use it.
414 (epg-import-keys-from-string): Use it.
416 2006-04-12 Daiki Ueno <ueno@unixuser.org>
418 * epf.el: Renamed from epg-file.el.
420 2006-04-12 Daiki Ueno <ueno@unixuser.org>
422 * epg.el (epg-status-GET_BOOL): New function.
423 (epg-status-GET_LINE): New function.
424 (epg-prompt-alist): New variable, to be filled.
426 * pgg-epg.el (mml2015-gpg-extract-signature-details): New function.
427 * epg.el (epg-signature-fingerprint): New function.
428 (epg-signature-set-fingerprint): New function.
429 (epg-status-VALIDSIG): New function.
431 * epg.el (epg-reset): Don't reset result.
432 (epg-start-decrypt): Reset result before epg-start.
433 (epg-start-verify): Ditto.
434 (epg-start-sign): Ditto.
435 (epg-start-encrypt): Ditto.
436 (epg-start-export-keys): Ditto.
437 (epg-start-import-keys): Ditto.
439 * Makefile.am (EXTRA_DIST): Added pgg-epg.el.
440 * pgg-epg.el: New file.
442 * epg.el (epg-start-export-keys): New function.
443 (epg-export-keys): New function.
444 (epg-start-import-keys): New function.
445 (epg-import-keys): New function.
446 (epg-verify-file): New function.
448 * epg-file.el (epg-file-write-region): Support public key encryption.
450 * epg.el (epg-passphrase-callback-function): Always display key-id.