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