* epg.el (epg-start): Signal an error if the process of CONTEXT is
[elisp/epg.git] / ChangeLog
1 2006-05-01  Daiki Ueno  <ueno@unixuser.org>
2
3         * epg.el (epg-start): Signal an error if the process of CONTEXT is
4         already running for other operations.
5
6 2006-04-30  Daiki Ueno  <ueno@unixuser.org>
7
8         * epa.el (epa-delete-keys): Support deletion of secret keys.
9
10         * pgg-epg.el (pgg-epg-decrypt-region): Convert line endings of the
11         decrypted text.
12
13         * epg.el (epg-read-output): Don't convert line endings of the
14         output file.
15         (epg-cancel): Set 'error result.
16
17 2006-04-29  Daiki Ueno  <ueno@unixuser.org>
18
19         * epg.el (epg-make-signature): Removed user-id; added
20         creation-time, expiration-time, pubkey-algorithm,
21         digest-algorithm.
22         (epg-process-sentinel): Abolished.
23         (epg-signature-to-string): Decode DN.
24         (epg-list-keys): Cache user-id in epg-user-id-alist.
25         (epg-make-user-id): Renamed name -> string.
26
27 2006-04-29  Daiki Ueno  <ueno@unixuser.org>
28
29         * epg.el (epg-status-ERRSIG): New function.
30         (epg-verify-file): Signal an error if we encounter ERRSIG status.
31         (epg-verify-string): Ditto.
32
33 2006-04-28  Daiki Ueno  <ueno@unixuser.org>
34
35         * epg.el: Added typecheck to accessors to objects.
36
37 2006-04-26  Daiki Ueno  <ueno@unixuser.org>
38
39         * epg.el (epg-status-GET_HIDDEN): Pass epg-context as the first
40         argument of passphrase-callback.
41         (epg-status-PROGRESS): Ditto.
42
43 2006-04-26  Daiki Ueno  <ueno@unixuser.org>
44
45         * epa.el (epa-select-keys): Don't set inhibit-quit when
46         recursive-edit is called.
47         (epg-cancel): New function.
48
49 2006-04-25  Daiki Ueno  <ueno@unixuser.org>
50
51         * epg.el (epg-process-sentinel): New function; set 'error if gpg
52         process exited abnormally, but we have not received an error
53         response from it.
54         (epg-sign-file): Signal an error only when a signature is not
55         created.
56         (epg-sign-string): Ditto.
57         (epg-encrypt-file): Signal an error if SIGN is specified and
58         signature is not created.
59         (epg-encrypt-string): Ditto.
60
61 2006-04-22  Daiki Ueno  <ueno@unixuser.org>
62
63         * epa.el (epa-key-widget-value-create): Decode DN.
64         (epa-list-keys): Add the PROTOCOL argument.
65         (epa-select-keys): Require CONTEXT as the first argument.
66
67         * epg.el (epg-gpgsm-program): New user option.
68         (epg-dn-type-alist): New variable.
69         (epg-start): Don't specify --command-fd if protocol is CMS.
70         (epg-list-keys): Require CONTEXT as the first argument.
71         (epg-dn-from-string): New function.
72         (epg-decode-dn): New function.
73
74 2006-04-21  Daiki Ueno  <ueno@unixuser.org>
75
76         * epa.el (epa-sign-keys): New command.
77
78         * epg.el (epg-start-sign-keys): New function.
79         (epg-sign-keys): New function.
80         (epg-status-GET_HIDDEN): Enable local quit.
81         (epg-status-GET_BOOL): Ditto.
82         (epg-status-GET_LINE): Ditto.
83
84 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
85
86         * epa.el (epa-list-keys-1): Add 'epa-list-keys property to keylist
87         region.
88
89 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
90
91         * pgg-epg.el (pgg-epg-secret-key-id-list): New variable.
92         (pgg-epg-passphrase-callback): New function.
93
94         * epa.el (epa-select-keys): Added "Cancel" button.
95
96 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
97
98         * epg.el (epg-signature-to-string): New function.
99
100 2006-04-20  Daiki Ueno  <ueno@unixuser.org>
101
102         * epa-file.el (epa-file-write-region): RECIPIENTS is now a list of
103         key objects.
104         * epa-dired.el (epa-dired-do-encrypt): RECIPIENTS is now a list of
105         key objects.
106
107         * epa.el (epa-select-keys): Added MODE argument.
108         (epa-encrypt-file): RECIPIENTS is now a list of key objects.
109
110         * epg.el (epg-status-SIG_CREATED): New function.
111         (epg-start-sign): epg-context-signers is now a list of key objects.
112         (epg-start-encrypt): RECIPIENTS is now a list of key objects.
113
114 2006-04-19  Daiki Ueno  <ueno@unixuser.org>
115
116         * epa.el (epa-verify-file): Show results in minibuffer.
117         * epg.el (epg-debug-buffer): New variable.
118         (epg-flush): New function.
119
120 2006-04-18  Daiki Ueno  <ueno@unixuser.org>
121
122         * epa.el (epa-export-keys): New command.
123         * epg.el (epg-start-export-keys): Accept a list of epg-key object
124         instead of a regexp.
125
126 2006-04-18  Daiki Ueno  <ueno@unixuser.org>
127
128         * epa.el (epa-keys-mode-map): Bind epa-list-keys; epa-import-key.
129         (epa-import-key): New command.
130
131         * epg.el (epg-delete-problem-alist): New constant.
132         (epg-status-DELETE_PROBLEM): New function.
133         (epg-start-delete-key): New function.
134         (epg-delete-key): New function.
135         (epg-wait-for-completion): Add the NO-EOF argument.
136
137 2006-04-18  Daiki Ueno  <ueno@unixuser.org>
138
139         * epg.el (epg-start): Insert the command-line arguments to the
140         debug buffer.
141         (epg-start-encrypt): Wait for BEGIN_ENCRYPTION.
142         (epg-start-delete-key): New function.
143         (epg-delete-key): New function.
144
145         * epa.el (epa-key): New widget.
146         (epa-key-widget-action): New function.
147         (epa-key-widget-value-create): New function.
148         (epa-key-widget-button-face-get): New function.
149         (epa-key-widget-help-echo): New function.
150
151 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
152
153         * epa-file.el (epa-file-write-region): Check if START is a string.
154
155 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
156
157         * epa-file.el: Rewritten with file-name-handler.
158         (epa-file-handler): New variable.
159         (epa-file-enable): New command.
160         (epa-file-disable): New command.
161
162         * epa-setup.el: Call epa-file-enable.
163
164 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
165
166         * epa-file.el (epa-passphrase): New variable.
167         (epa-file-passphrase-callback-function): New function.
168         (epa-find-file): Reset buffer-undo-list; set
169         buffer-file-coding-system to last-coding-system-used after
170         decoding.
171
172 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
173
174         * epa-file.el (epa-write-file): Try to write region to "/" to get
175         last-coding-system-used to be set.
176
177 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
178
179         * epa-file.el: New implementation of epf.el.
180
181         * epf.el: Abolished.
182
183 2006-04-17  Daiki Ueno  <ueno@unixuser.org>
184
185         * epa.el (epa-verify-file): Display verify result.
186
187         * epg.el (epg-invalid-recipients-alist): New variable.
188         (epg-status-INV_RECP): New function.
189         (epg-status-NO_RECP): New function.
190
191         * epa.el (epa-keys-mode-map): Bind epa-decrypt-file,
192         epa-verify-file, epa-sign-file, and epa-encrypt-file.
193         (epa-decrypt-file): New function imported from epa-dired.el.
194         (epa-verify-file): New function imported from epa-dired.el.
195         (epa-sign-file): New function imported from epa-dired.el.
196         (epa-encrypt-file): New function imported from epa-dired.el.
197
198 2006-04-16  Daiki Ueno  <ueno@unixuser.org>
199
200         * epa.el (epa-select-keys): Renamed from epa-ask-keys; use
201         recursive-edit.
202         * epa-dired.el (epa-dired-encrypt-file): Use epa-select-keys.
203
204 2006-04-16  Daiki Ueno  <ueno@unixuser.org>
205
206         * epa-setup.el: New file.
207         * epa-dired.el: New file.
208
209         * epg.el (epg-colons-pub-spec): Abolished.
210         (epg-colons-sec-spec): Abolished.
211         (epg-colons-uid-spec): Abolished.
212         (epg-colons-fpr-spec): Abolished.
213         (epg-key-validity-alist): New variable.
214         (epg-key-capablity-alist): New variable.
215         (epg-make-key): New object epg-key.
216         (epg-make-sub-key): New object epg-sub-key.
217         (epg-make-user-id): New object epg-user-id.
218         (epg-list-keys-1): Renamed from epg-list-keys.
219         (epg-list-keys): Rewritten.
220
221 2006-04-15  Daiki Ueno  <ueno@unixuser.org>
222
223         * epg.el (epg-list-keys): Make the NAME argument optional.
224
225 2006-04-13  Daiki Ueno  <ueno@unixuser.org>
226
227         * epa.el: Added header.
228
229         * epg.el (epg-list-keys): Specify --with-fingerprint.
230         (epg-colons-fpr-spec): New variable.
231         (epg-colons-pub-spec): Renamed trust -> validity and ownertrust ->
232         owner-trust.
233         (epg-colons-sec-spec): Ditto.
234         (epg-colons-uid-spec): Renamed trust -> validity.
235
236 2006-04-13  Daiki Ueno  <ueno@unixuser.org>
237
238         * epa.el: New file.
239
240         * epg.el (epg-cipher-algorithm-alist): New constant.
241         (epg-pubkey-algorithm-alist): New constant.
242         (epg-digest-algorithm-alist): New constant.
243         (epg-compress-algorithm-alist): New constant.
244         (epg-configuration): New function.
245         (epg-start): Don't specify --yes.
246
247 2006-04-13  Daiki Ueno  <ueno@unixuser.org>
248
249         * epg.el (epg-make-data-from-file): New function.
250         (epg-make-data-from-string): New function.
251         (epg-data-file): New function.
252         (epg-data-string): New function.
253         (epg-start-decrypt): Get a cipher text from a data object.
254         (epg-delete-output-file): New function.
255         (epg-decrypt-file): Add the 3rd argument PLAIN to specify where
256         the output goes.
257         (epg-start-verify): Get a signature and signed-text from a data
258         object.
259         (epg-verify-file): Added the 3rd argument PLAIN to specify where
260         the output goes; return the plain text if PLAIN is nil.
261         (epg-verify-string): Return the plain text.
262         (epg-start-sign): Get a plain text from a data object.
263         (epg-sign-file): Added the 3rd argument SIGNATURE to specify where
264         the output goes.
265         (epg-start-encrypt): Get a plain text from a data object.
266         (epg-encrypt-file): Added the 4th argument CIPHER to specify where
267         the output goes.
268         (epg-start-import-keys): Get keys from a data object.
269         (epg-import-keys-1): New function.
270         (epg-import-keys-from-file): Use it.
271         (epg-import-keys-from-string): Use it.
272
273 2006-04-12  Daiki Ueno  <ueno@unixuser.org>
274
275         * epf.el: Renamed from epg-file.el.
276
277 2006-04-12  Daiki Ueno  <ueno@unixuser.org>
278
279         * epg.el (epg-status-GET_BOOL): New function.
280         (epg-status-GET_LINE): New function.
281         (epg-prompt-alist): New variable, to be filled.
282
283         * pgg-epg.el (mml2015-gpg-extract-signature-details): New function.
284         * epg.el (epg-signature-fingerprint): New function.
285         (epg-signature-set-fingerprint): New function.
286         (epg-status-VALIDSIG): New function.
287
288         * epg.el (epg-reset): Don't reset result.
289         (epg-start-decrypt): Reset result before epg-start.
290         (epg-start-verify): Ditto.
291         (epg-start-sign): Ditto.
292         (epg-start-encrypt): Ditto.
293         (epg-start-export-keys): Ditto.
294         (epg-start-import-keys): Ditto.
295
296         * Makefile.am (EXTRA_DIST): Added pgg-epg.el.
297         * pgg-epg.el: New file.
298
299         * epg.el (epg-start-export-keys): New function.
300         (epg-export-keys): New function.
301         (epg-start-import-keys): New function.
302         (epg-import-keys): New function.
303         (epg-verify-file): New function.
304
305         * epg-file.el (epg-file-write-region): Support public key encryption.
306
307         * epg.el (epg-passphrase-callback-function): Always display key-id.
308