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