/[winpt]/trunk/Include/wptGPG.h
ViewVC logotype

Contents of /trunk/Include/wptGPG.h

Parent Directory Parent Directory | Revision Log Revision Log


Revision 214 - (show annotations)
Sun May 14 18:40:36 2006 UTC (18 years, 9 months ago) by twoaday
File MIME type: text/plain
File size: 8558 byte(s)
2006-05-14  Timo Schulz  <ts@g10code.de>
                                                                                
        * wptKeyCache.cpp (gpg_keycache_update_attr): Parse
        preferred keyserver URL.
        * wptHTTP.cpp (extractHostInfo): Fix segv.
        * wptGPGUtil.cpp (gpg_find_key_subpacket): Ignore default
        gpg.conf.
        * wptKeyserverSearchDlg.cpp (search_hkp_keys): Do not
        assume an existing user id.
        * wptPassphraseCB.cpp (passphrase_cb): Automatic cancel
        if no passphrase is available.

(for complete list of changes, see Src/ChangeLog)

About to release 0.12.1


1 /* wptGPG.h - GnuPG interface
2 * Copyright (C) 2000-2006 Timo Schulz
3 *
4 * This file is part of WinPT.
5 *
6 * WinPT is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU General Public License
8 * as published by the Free Software Foundation; either version 2
9 * of the License, or (at your option) any later version.
10 *
11 * WinPT is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * General Public License for more details.
15 *
16 * You should have received a copy of the GNU General Public License
17 * along with WinPT; if not, write to the Free Software Foundation,
18 * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
19 */
20
21 #ifndef WPT_GPG_H
22 #define WPT_GPG_H
23
24 #include <gpgme.h>
25 #include "wptKeyCache.h"
26 #include "wptNLS.h"
27
28
29 #define NO_STRICT 0
30
31 #define key_is_useable(key) (!(key)->revoked && \
32 !(key)->expired && \
33 !(key)->disabled)
34
35 enum setup_t {
36 SETUP_KEYGEN = 1,
37 SETUP_IMPORT = 2,
38 SETUP_EXISTING = 3
39 };
40
41 enum gpg_cmd_t {
42 GPG_CMD_DECRYPT = 0,
43 GPG_CMD_SIGN = 1
44 };
45
46 enum keycache_t {
47 KEYCACHE_PRV = 0,
48 KEYCACHE_PUB = 1
49 };
50
51 enum entry_t {
52 ENTRY_OPAQUE = 1,
53 ENTRY_SINGLE = 2,
54 ENTRY_MULTI = 3,
55 ENTRY_GROUP = 4,
56 };
57
58 struct gpg_card_s;
59 typedef struct gpg_card_s *gpg_card_t;
60
61 /* Keycache refresh context. */
62 struct refresh_cache_s {
63 int kr_reload;
64 int kr_update;
65 int tr_update;
66 };
67
68 struct gpg_option_s {
69 struct gpg_option_s *next;
70 char *name;
71 char *val;
72 unsigned int used:1;
73 int type;
74 };
75 typedef struct gpg_option_s *gpg_option_t;
76
77 struct gpg_member_s {
78 struct gpg_member_s * next;
79 char *name;
80 unsigned int used:1;
81 };
82 typedef struct gpg_member_s *gpg_member_t;
83
84 struct gpg_group_s {
85 struct gpg_group_s *next;
86 struct gpg_member_s *list;
87 char *name;
88 unsigned int used:1;
89 };
90 typedef struct gpg_group_s *gpg_group_t;
91
92 struct gpg_optfile_s {
93 struct gpg_option_s *list;
94 struct gpg_group_s *grp;
95 };
96 typedef struct gpg_optfile_s *gpg_optfile_t;
97
98
99 struct passphrase_cb_s {
100 int gpg_cmd; /* sign or decrypt. */
101 int pwd_init; /* 1 = passphrase request via dialog. */
102 char *pwd; /* actual passphrase. */
103 char info[1024]; /* hold up the info message */
104 char *title; /* dialog title. */
105 char keyid[16+1]; /* keyid of the secret key the pwd can be used for. */
106 HWND hwnd; /* handle of the dialog window. */
107 int cancel; /* 1 = user cancelled passphrase request. */
108 unsigned int is_card:1; /* 1 = key stored on a smart card. */
109 unsigned int bad_pwd:1; /* 1 = last passphrase was bad. */
110 gpgme_ctx_t gpg;
111 gpgme_recipient_t recipients;
112 struct {
113 int sym_algo;
114 int s2k_mode;
115 int s2k_hash;
116 } sym;
117 };
118
119
120 /* This variable is 1 if IDEA is available. */
121 extern int idea_available;
122
123 /*-- wptGPG.cpp --*/
124 char* get_gnupg_default_key( void );
125 int set_gnupg_default_key( const char *key );
126 char* get_gnupg_config (void);
127 char* get_gnupg_keyring_from_options( const char *fname, int pub );
128 int check_gnupg_config (const char *fname, int *secrings, int *pubrings);
129 char* get_gnupg_path( void );
130 int check_gnupg_prog( void );
131 int gnupg_access_files (void);
132 char* get_gnupg_prog( void );
133 char* get_gnupg_keyring (int pub, int strict);
134 char* get_gnupg_cfgfile (void);
135 int set_gnupg_options( const char *buf, size_t buflen );
136 int gnupg_load_config (void);
137 char* multi_gnupg_path (int strict);
138
139 int check_gnupg_options (const char *buf);
140 void init_gnupg_table (void);
141 void free_gnupg_table (void);
142 int keyring_check_last_access (void);
143 const char* gnupg_check_file_ext (const char *fname, int *r_type);
144 int gpg_check_permissions (int showmsg);
145 int gnupg_check_homedir (void);
146 int gnupg_access_keyring (int _pub);
147 void gnupg_backup_options ();
148 void gnupg_backup_keyrings (int auto_backup, int backup_mode);
149 void gnupg_display_error (void);
150 int gnupg_copy_keyrings (void);
151 int check_gnupg_engine (const char *need_gpg_ver,
152 int *r_major, int *r_minor, int *r_patch);
153
154 /*-- wptGPGME.cpp --*/
155 const char * get_signature_status( gpgme_sigsum_t sigstat );
156 void keycache_reload( HWND dlg );
157
158 gpgme_error_t get_pubkey (const char *keyid, gpgme_key_t *ret_key);
159 gpgme_error_t winpt_get_pubkey (const char *keyid, struct winpt_key_s *k);
160 gpgme_error_t get_seckey (const char *keyid, gpgme_key_t *ret_skey);
161 gpgme_error_t winpt_get_seckey (const char *keyid, struct winpt_key_s *k);
162
163 void keycache_reload( HWND dlg );
164 void keycache_release (int cleanup);
165 gpgme_error_t keycache_update (int is_sec, const char *keyid);
166 gpgme_error_t keycache_init (const char *pubring, const char * secring);
167 gpg_keycache_t keycache_get_ctx (int _pub);
168
169 int count_insecure_elgkeys (void);
170
171 int gpg_encrypt_symmetric (void);
172 const char *get_gpg_sigstat (gpgme_sigsum_t sum);
173 int check_ultimate_trusted_key (void);
174 bool secret_key_available (void);
175
176 /*-- wptGPGParser.cpp --*/
177 /* find */
178 gpg_group_t find_group( gpg_optfile_t opt, const char *str );
179 gpg_option_t find_option( gpg_optfile_t opt, const char *str );
180 gpg_member_t find_member( gpg_optfile_t opt, const char *grp, const char *str );
181 /* delete */
182 int delete_group( gpg_optfile_t opt, const char *str );
183 int delete_member( gpg_optfile_t opt, const char *grp, const char *str );
184 int delete_option( gpg_optfile_t opt, const char *str );
185 /* add */
186 int modify_entry( gpg_optfile_t opt, int type, const char *name, const char *val );
187 int add_entry( gpg_optfile_t opt, int type, const char *name, const char *val );
188 int add_member( gpg_optfile_t opt, const char *grp, const char *str );
189 int add_group( gpg_optfile_t opt, const char *str );
190 /* high-level */
191 int parse_gpg_options( const char *file, gpg_optfile_t *r_opt );
192 int commit_gpg_options( const char *file, gpg_optfile_t opt );
193 void release_gpg_options( gpg_optfile_t opt );
194 /* memory */
195 void release_group( gpg_group_t grp );
196
197 /*-- wptPassphraseCB.cpp --*/
198 enum passdlg_t {
199 PASSDLG_REPEAT = 0,
200 PASSDLG_INIT = 1,
201 PASSDLG_STRICT = 2,
202 PASSDLG_NOTEMPTY= 4
203 };
204
205 void set_gpg_passphrase_cb (passphrase_cb_s *cb, gpgme_ctx_t ctx,
206 int cmd, HWND hwnd, const char *title);
207 void release_gpg_passphrase_cb (passphrase_cb_s *cb);
208 void release_gpg_recipients (gpgme_recipient_t *recipients);
209
210 char * request_passphrase (const char *title, int flags, int *ret_cancel);
211 char * request_passphrase2 (const char *title, int flags, int *ret_cancel);
212 const char * passphrase_cb (void *opaque, const char * desc, void *r_hd);
213 char * get_key_userid (const char *keyid);
214 int check_passwd_quality (const char *pass, int strict);
215
216 /*-- wptClipboard.cpp --*/
217 gpgme_error_t gpg_clip_istext_avail (int *r_val);
218 gpgme_error_t gpg_clip_is_secured (int *r_type, int *r_val);
219 gpgme_error_t gpg_clip_get_pgptype (int *r_type);
220 gpgme_error_t gpg_clip_parse_pgpid (const char *data, int *r_type);
221
222 /* wptGPGMEData.cpp --*/
223 gpgme_error_t gpg_data_new_from_clipboard (gpgme_data_t *r_dh, int wraplen);
224 void gpg_data_release_and_set_clipboard (gpgme_data_t dh, int chg_ver);
225 size_t gpg_data_readline (gpgme_data_t dh, char *line, size_t nbytes);
226
227 gpgme_error_t gpg_data_release_and_set_file (gpgme_data_t dh, const char *fname);
228 gpgme_error_t gpg_data_mail_quote (gpgme_data_t *r_dh);
229 gpgme_error_t gpg_data_extract_plaintext (gpgme_data_t sig, gpgme_data_t *r_plain);
230 void gpg_data_putc (gpgme_data_t hd, int c);
231
232 /*-- wptGPGUtil.cpp --*/
233 gpgme_error_t gpg_rebuild_cache (char **r_inf);
234 gpgme_error_t gpg_get_version (char **r_inf);
235 void gpg_set_debug_mode (int val);
236 gpgme_error_t gpg_export_seckey (const char *keyid, const char *outfile);
237 gpgme_error_t gpg_manage_ownertrust (char **data, int do_export);
238 gpgme_error_t gpg_get_photoid_data (const char *keyid, char **r_status_data,
239 unsigned char **r_data,
240 unsigned long *ndata);
241 gpgme_error_t gpg_revoke_cert (int desig_revoke, const char *inp_data,
242 const char *keyid, char **r_revcert);
243 gpgme_error_t gpg_decode_c_string (const char *src, char **destp, size_t len);
244 gpgme_error_t gpg_import_key_list (const char *fname, char **r_out);
245 gpgme_error_t gpg_extract_keys (const char *keyfile, const char **keys, DWORD nkeys,
246 char **new_keyfile);
247 gpgme_error_t get_uat_validity (const char *keyid, gpgme_validity_t *r_valid);
248 gpgme_error_t gpg_get_recipients (const char *file, gpgme_recipient_t *r_list);
249 gpgme_error_t gpg_find_key_subpacket (const char *key, int subpktid,
250 char **value);
251
252 #endif /* WPT_GPG_H */

Properties

Name Value
svn:eol-style native

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26