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