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