/[winpt]/trunk/Src/wptPreferencesDlg.cpp
ViewVC logotype

Contents of /trunk/Src/wptPreferencesDlg.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 105 - (show annotations)
Wed Nov 30 10:22:00 2005 UTC (19 years, 3 months ago) by twoaday
File size: 12376 byte(s)
Several cleanups and improved translation.


1 /* wptPreferencesDlg.cpp - Dialog for the preferences
2 * Copyright (C) 2001, 2002, 2003, 2005 Timo Schulz
3 *
4 * This file is part of WinPT.
5 *
6 * WinPT is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License as published by
8 * the Free Software Foundation; either version 2 of the License, or
9 * (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
14 * GNU 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 #ifdef HAVE_CONFIG_H
21 #include <config.h>
22 #endif
23
24 #include <windows.h>
25 #include <shlobj.h>
26
27 #include "wptNLS.h"
28 #include "wptGPG.h"
29 #include "wptCommonCtl.h"
30 #include "wptDlgs.h"
31 #include "wptTypes.h"
32 #include "wptErrors.h"
33 #include "wptRegistry.h"
34 #include "wptHotkey.h"
35 #include "wptW32API.h"
36 #include "wptVersion.h"
37 #include "wptAgent.h"
38 #include "wptKeyserver.h"
39 #include "resource.h"
40
41
42 /* Dialog IDs of all hotkeys. */
43 static int hotkeys[] = {
44 IDC_PREFS_CLIP_ENCRYPT,
45 IDC_PREFS_CLIP_DECRYPT_VERIFY,
46 IDC_PREFS_CLIP_SIGN,
47 IDC_PREFS_CLIP_SIGNENC,
48 IDC_PREFS_CWS_ENCRYPT,
49 IDC_PREFS_CWS_DECRYPT_VERIFY,
50 IDC_PREFS_CWS_SIGN,
51 IDC_PREFS_CWS_SIGNENC,
52 0
53 };
54
55
56 /* Check that the given hotkey is in A..Z or a..z. */
57 static int
58 check_hotkey (char * key)
59 {
60 if (*key >= 'A' && *key <= 'Z')
61 return 1;
62 else if (*key >= 'a' && *key <= 'z') {
63 *key = *key - 32;
64 return 1;
65 }
66 return 0;
67 }
68
69
70 /* Disable all hotkey controls in the dialog @dlg if val is 1. */
71 static void
72 disable_hotkey_items (HWND dlg, int val)
73 {
74 int mode = val? FALSE : TRUE;
75 int i, id;
76
77 for (i=0; (id = hotkeys[i]); i++)
78 EnableWindow (GetDlgItem (dlg, id), mode);
79 }
80
81
82
83 /* En- or disable the backup items in the dialog @dlg.
84 If val != 0 activate them, disable them otherwise. */
85 static void
86 enable_backup_items (HWND dlg, int val)
87 {
88 int mode = val? TRUE : FALSE;
89
90 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKHOME), mode);
91 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKUSER), mode);
92 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKSELECT), mode);
93 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKPATH), mode);
94 }
95
96
97 /* Initialize the combox in the dialog @dlg with the valid list modes. */
98 static void
99 init_keylist_modes (HWND dlg)
100 {
101 HWND cb = GetDlgItem (dlg, IDC_PREFS_LISTMODE);
102 combox_add_string (cb, (char *)"NORMAL");
103 combox_add_string (cb, (char *)"MINIMAL");
104 SendMessage (cb, CB_SETCURSEL, (WPARAM)reg_prefs.keylist_mode, 0);
105 }
106
107
108 /* Initialize the combobox in the dialog @dlg with the valid wipe modes. */
109 static void
110 init_wipe_modes (HWND dlg)
111 {
112 HWND cb = GetDlgItem (dlg, IDC_PREFS_WIPEMODE);
113 combox_add_string (cb, (char *)"Simple");
114 combox_add_string (cb, (char *)"DoD");
115 combox_add_string (cb, (char *)"Gutmann");
116 SendMessage (cb, CB_SETCURSEL, (WPARAM)reg_prefs.wipe_mode, 0);
117 }
118
119
120 /* Dialog box procedure for the WinPT preferences. */
121 BOOL CALLBACK
122 prefs_dlg_proc (HWND dlg, UINT msg, WPARAM wparam, LPARAM lparam)
123 {
124 int rc;
125 int i, id;
126 char t[2];
127 char path[256], * p;
128 HWND cb;
129
130 switch (msg) {
131 case WM_INITDIALOG:
132 SetWindowText (dlg, _("WinPT Preferences"));
133 SetDlgItemText (dlg, IDC_PREFS_SECMODE, _("Do not use any &temporary files"));
134 SetDlgItemText (dlg, IDC_PREFS_VIEWER, _("Use clipboard &viewer to display the plaintext"));
135 SetDlgItemText (dlg, IDC_PREFS_WWINFO, _("Word wrap cleartext &signatures at column"));
136 SetDlgItemText (dlg, IDC_PREFS_DISABLE_HOTKEYS, _("&Disable hotkeys (Not recommended!)"));
137 SetDlgItemText (dlg, IDC_PREFS_TRUST, _("Skip key validation and assume that keys are always fully trusted"));
138 SetDlgItemText (dlg, IDC_PREFS_AUTOBACKUP, _("&Automatic keyring backup when WinPT closes"));
139 SetDlgItemText (dlg, IDC_PREFS_BAKHOME, _("Backup to GPG &home folder"));
140 SetDlgItemText (dlg, IDC_PREFS_BAKUSER, _("Backup to:"));
141 SetDlgItemText (dlg, IDC_PREFS_KEYLISTINF, _("Select &key list mode"));
142 SetDlgItemText (dlg, IDC_PREFS_WIPEINF, _("Select &wipe mode"));
143 SetDlgItemText (dlg, IDC_PREFS_KSINF, _("Keyserver &config"));
144 SetDlgItemText (dlg, IDC_PREFS_CACHEINF, _("Cache &passphrases for 'n' seconds"));
145 SetDlgItemText (dlg, IDC_PREFS_CACHEHINT, _("(CTRL+ALT+F to clear the cache)"));
146 SetDlgItemText (dlg, IDC_PREFS_ALLOPTINF, _("General options"));
147 SetDlgItemText (dlg, IDC_PREFS_CLIPINF, _("Clipboard hotkeys"));
148 SetDlgItemText (dlg, IDC_PREFS_CURRINF, _("Current window hotkeys"));
149 SetDlgItemText (dlg, IDCANCEL, _("&Cancel"));
150
151 SetDlgItemInt( dlg, IDC_PREFS_CACHETIME, reg_prefs.cache_time, TRUE );
152 SetDlgItemInt( dlg, IDC_PREFS_WORDWRAP, reg_prefs.word_wrap, TRUE );
153 if (reg_prefs.backup.path)
154 SetDlgItemText (dlg, IDC_PREFS_BAKPATH, reg_prefs.backup.path);
155 if (reg_prefs.kserv_conf)
156 SetDlgItemText (dlg, IDC_PREFS_KSERVER, reg_prefs.kserv_conf);
157
158 for (i=0; (id=hotkeys[i]); i++)
159 SetDlgItemText (dlg, id, reg_hotkeys[i].key);
160 CheckDlgButton( dlg, IDC_PREFS_DISABLE_HOTKEYS,
161 reg_prefs.no_hotkeys ? BST_CHECKED : BST_UNCHECKED );
162 CheckDlgButton( dlg, IDC_PREFS_SECMODE,
163 reg_prefs.use_tmpfiles ? BST_UNCHECKED : BST_CHECKED );
164 CheckDlgButton( dlg, IDC_PREFS_VIEWER,
165 reg_prefs.use_viewer ? BST_CHECKED: BST_UNCHECKED );
166 CheckDlgButton( dlg, IDC_PREFS_TRUST,
167 reg_prefs.always_trust? BST_CHECKED : BST_UNCHECKED );
168 CheckDlgButton( dlg, IDC_PREFS_AUTOBACKUP,
169 reg_prefs.auto_backup? BST_CHECKED : BST_UNCHECKED );
170 CheckDlgButton( dlg, IDC_PREFS_BAKHOME,
171 reg_prefs.backup.mode==1? BST_CHECKED : BST_UNCHECKED );
172 CheckDlgButton( dlg, IDC_PREFS_BAKUSER,
173 reg_prefs.backup.mode==2? BST_CHECKED : BST_UNCHECKED );
174 if( reg_prefs.no_hotkeys )
175 disable_hotkey_items( dlg, 1 );
176 if (!reg_prefs.auto_backup)
177 enable_backup_items (dlg, 0);
178 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKPATH),
179 reg_prefs.backup.mode==1?FALSE : TRUE);
180 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKSELECT),
181 reg_prefs.backup.mode==1? FALSE : TRUE);
182 init_keylist_modes (dlg);
183 init_wipe_modes (dlg);
184 center_window (dlg, NULL);
185 SetForegroundWindow (dlg);
186 return TRUE;
187
188 case WM_SYSCOMMAND:
189 if (LOWORD (wparam) == SC_CLOSE)
190 EndDialog (dlg, TRUE);
191 return FALSE;
192
193 case WM_COMMAND:
194 switch( HIWORD(wparam) ) {
195 case BN_CLICKED:
196 switch( (int)LOWORD( wparam ) ) {
197 case IDC_PREFS_DISABLE_HOTKEYS:
198 reg_prefs.no_hotkeys ^= 1;
199 disable_hotkey_items( dlg, reg_prefs.no_hotkeys );
200 break;
201
202 case IDC_PREFS_TRUST:
203 reg_prefs.always_trust ^= 1;
204 if( reg_prefs.always_trust ) {
205 msg_box (dlg,
206 _("In most cases it is not a good idea to enable this setting.\n"
207 "If you know what you are doing let this flag enabled, otherwise\n"
208 "it is safe to leave this flag untouched."),
209 _("Preferences"), MB_ICONWARNING|MB_OK );
210 }
211 break;
212
213 case IDC_PREFS_AUTOBACKUP:
214 reg_prefs.auto_backup ^= 1;
215 enable_backup_items (dlg, reg_prefs.auto_backup);
216 if (reg_prefs.auto_backup == 1) {
217 if (!IsDlgButtonChecked (dlg, IDC_PREFS_BAKHOME) &&
218 !IsDlgButtonChecked (dlg, IDC_PREFS_BAKUSER))
219 CheckDlgButton (dlg, IDC_PREFS_BAKHOME, BST_CHECKED);
220 }
221 break;
222
223 case IDC_PREFS_BAKHOME:
224 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKSELECT), FALSE);
225 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKPATH), FALSE);
226 break;
227
228 case IDC_PREFS_BAKUSER:
229 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKSELECT), TRUE);
230 EnableWindow (GetDlgItem (dlg, IDC_PREFS_BAKPATH), TRUE);
231 break;
232 }
233 break;
234 }
235 switch( LOWORD( wparam ) ) {
236 case IDC_PREFS_BAKSELECT:
237 const char *bpath;
238 bpath = get_folder_dlg (dlg, _("Select GPG backup path"), NULL);
239 if (bpath)
240 SetDlgItemText (dlg, IDC_PREFS_BAKPATH, bpath);
241 break;
242
243 case IDC_PREFS_KSELFILE: {
244 const char * name;
245 name = get_fileopen_dlg (dlg, _("Please select a keyserver.conf file"),
246 NULL, NULL);
247 if (name != NULL)
248 SetDlgItemText (dlg, IDC_PREFS_KSERVER, name);
249 break; }
250
251 case IDOK:
252 rc = GetDlgItemInt( dlg, IDC_PREFS_CACHETIME, NULL, FALSE );
253 if( !rc )
254 reg_prefs.cache_time = 0;
255 else if( rc > 3600 ) {
256 msg_box( dlg, _("Please enter a value that is between 1-3600.\nIt is not "
257 "a good idea to cache the passphrase more than one hour."),
258 _("Preferences"), MB_ERR );
259 SetDlgItemInt( dlg, IDC_PREFS_CACHETIME, 0, FALSE );
260 return TRUE;
261 }
262 if (reg_prefs.cache_time != rc)
263 agent_flush_cache ();
264 reg_prefs.cache_time = rc;
265 rc = GetDlgItemInt( dlg, IDC_PREFS_WORDWRAP, NULL, FALSE );
266 if( !rc )
267 reg_prefs.word_wrap = 0;
268 else if( rc > 80 ) {
269 msg_box( dlg, _("Please enter a value between 1-80."), _("Preferences"), MB_ERR );
270 return TRUE;
271 }
272 reg_prefs.word_wrap = rc;
273 reg_prefs.use_tmpfiles = IsDlgButtonChecked( dlg, IDC_PREFS_SECMODE )? 0 : 1;
274 reg_prefs.use_viewer = IsDlgButtonChecked( dlg, IDC_PREFS_VIEWER )? 1 : 0;
275 reg_prefs.backup.mode = IsDlgButtonChecked( dlg, IDC_PREFS_BAKHOME ) ? 1 :
276 IsDlgButtonChecked( dlg, IDC_PREFS_BAKUSER )? 2 : 0;
277 if( reg_prefs.backup.mode == 2 ) {
278 if( !GetDlgItemText( dlg, IDC_PREFS_BAKPATH, path, sizeof (path)-1 )
279 || dir_exist_check( path ) ) {
280 msg_box( dlg, _("The specified backup folder is invalid."),
281 _("Preferences"), MB_ERR );
282 return TRUE;
283 }
284 free_if_alloc (reg_prefs.backup.path);
285 p = reg_prefs.backup.path = m_strdup (path);
286 if (!p)
287 BUG (0);
288 }
289 free_if_alloc (reg_prefs.kserv_conf);
290 if (!GetDlgItemText (dlg, IDC_PREFS_KSERVER, path, sizeof (path)-1)
291 || file_exist_check (path)) {
292 rc = msg_box (dlg, _("The specified keyserver config file is invalid.\n\n"
293 "Create new default config file?"),
294 _("Preferences"), MB_ERR|MB_YESNO);
295 if (rc == IDNO)
296 return TRUE;
297 else
298 {
299 char cwd[256], * fn;
300 FILE * fp = fopen ("keyserver.conf", "wb");
301 if (fp) {
302 fprintf (fp, "%s\r\n", DEF_HKP_KEYSERVER);
303 fclose (fp);
304 }
305 GetCurrentDirectory (DIM (cwd)-1, cwd);
306 fn = make_filename (cwd, "keyserver", "conf");
307 memset (path, 0, sizeof( path));
308 strncpy (path, fn, DIM (path)-1);
309 free_if_alloc (fn);
310 }
311 }
312 p = reg_prefs.kserv_conf = m_strdup (path);
313 if (!p)
314 BUG (0);
315
316 cb = GetDlgItem( dlg, IDC_PREFS_LISTMODE );
317 reg_prefs.keylist_mode = SendMessage( cb, CB_GETCURSEL, 0, 0 );
318
319 cb = GetDlgItem( dlg, IDC_PREFS_WIPEMODE );
320 reg_prefs.wipe_mode = SendMessage( cb, CB_GETCURSEL, 0, 0 );
321
322 if (IsDlgButtonChecked (dlg, IDC_PREFS_DISABLE_HOTKEYS)) {
323 hotkeys_unregister (glob_hwnd);
324 reg_prefs.no_hotkeys = 1;
325 }
326 else {
327 reg_prefs.no_hotkeys = 0;
328 for( i = 0; (id = hotkeys[i]); i++ ) {
329 rc = GetDlgItemText( dlg, id, t, 2 );
330 if( rc && check_hotkey( &t[0] ) )
331 hotkey_enable( &reg_hotkeys[i], t );
332 else
333 hotkey_disable( &reg_hotkeys[i] );
334 }
335 set_reg_entry (HKEY_CURRENT_USER, "Software\\WinPT", "DisableHotkeys", "0");
336 reg_prefs.no_hotkeys = 0;
337 }
338
339 if ((rc = set_reg_winpt_prefs (&reg_prefs)))
340 msg_box (dlg, winpt_strerror (rc), _("Preferences"), MB_ERR);
341
342 if (reg_prefs.no_hotkeys == 0) {
343 hotkeys_unregister (glob_hwnd);
344 hotkeys_modify ();
345 if ((rc = hotkeys_register (glob_hwnd)))
346 msg_box (NULL, winpt_strerror (rc), _("Hotkeys"), MB_ERR);
347 }
348 EndDialog (dlg, TRUE);
349 return TRUE;
350
351 case IDCANCEL:
352 EndDialog( dlg, FALSE );
353 return FALSE;
354 }
355 break;
356 }
357
358 return FALSE;
359 }

Properties

Name Value
svn:eol-style native

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26