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

Diff of /trunk/Src/WinPT.cpp

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 80 by twoaday, Wed Nov 16 11:05:16 2005 UTC revision 172 by twoaday, Mon Jan 30 13:47:35 2006 UTC
# Line 1  Line 1 
1  /* WinPT.cpp - Windows Privacy Tray (WinPT)  /* WinPT.cpp - Windows Privacy Tray (WinPT)
2   *      Copyright (C) 2000-2005 Timo Schulz   *      Copyright (C) 2000-2006 Timo Schulz
3   *   *
4   * This file is part of WinPT.   * This file is part of WinPT.
5   *   *
# Line 22  Line 22 
22  #endif  #endif
23    
24  #include <windows.h>  #include <windows.h>
25    #include <shlobj.h>
26    
27  #include "resource.h"  #include "resource.h"
28  #include "wptTypes.h"  #include "wptTypes.h"
# Line 40  Line 41 
41  #include "wptCardEdit.h"  #include "wptCardEdit.h"
42  #include "wptCrypto.h"  #include "wptCrypto.h"
43    
44  #define MIN_GPG_VER   "1.4.2"   /* Minimal GPG version. */  void remove_crit_file_attrs (const char *fname, int force);
 #define MIN_GPGME_VER "1.2.0"   /* Minimal GPGME version. */  
45    
46    
47  HINSTANCE glob_hinst;   /* global instance for the dialogs */  HINSTANCE glob_hinst;   /* global instance for the dialogs */
48  HWND glob_hwnd;         /* global window handle for the dialogs */  HWND glob_hwnd;         /* global window handle for the dialogs */
49  HWND activ_hwnd;  HWND activ_hwnd;
 LOCK mo_file;  
50  int scard_support = 0;  int scard_support = 0;
51  int debug = 0;  int debug = 0;
52  int mobile = 0;  int mobile = 0;
# Line 96  static void Line 95  static void
95  load_gettext (int prev_inst)  load_gettext (int prev_inst)
96  {  {
97      char *nls = NULL;      char *nls = NULL;
     char *file = NULL;  
98    
99      nls = get_gettext_lang ();      nls = get_gettext_lang ();
100      if (nls) {      if (nls != NULL) {
101          set_gettext_file ("winpt", nls);          set_gettext_file ("winpt", nls);
         file = make_filename (nls, "winpt", "mo");  
         if (!file_exist_check (nls) && init_file_lock (&mo_file, file))  {  
             if (!prev_inst)  
                 msg_box (NULL, _("Could not initizalize file lock.\n"  
                                  "Native Language Support"),  
                          _("WinPT Error"), MB_ERR);  
         }  
102          free_if_alloc (nls);          free_if_alloc (nls);
103        }
104    }
105    
106    
107    /* Return true if the GPG environment is useable. */
108    static bool
109    gpg_prefs_ok (void)
110    {
111        char *p;
112    
113        p = get_reg_entry_gpg4win ("gpg.exe");
114        if (!p || file_exist_check (p) != 0) {
115            free_if_alloc (p);
116            p = get_reg_entry_gpg ("gpgProgram");
117            if (!p || file_exist_check (p) != 0) {
118                free_if_alloc (p);
119                return false;
120            }
121        }
122        free_if_alloc (p);
123        p = get_reg_entry_gpg4win (NULL);    
124        if (!p || dir_exist_check (p) != 0) {
125            free_if_alloc (p);
126            p = get_reg_entry_gpg ("HomeDir");
127            if (!p || dir_exist_check (p) != 0) {
128                free_if_alloc (p);
129                return false;
130            }
131        }
132        free_if_alloc (p);
133        return true;
134    }
135    
136    
137    /* Check gpg files if they are read-only and ask the user
138       if this should be corrected. */
139    static void
140    check_readonly_attr (const char *homedir)
141    {
142        const char *files[] = {"pubring.gpg", "secring.gpg", "trustdb.gpg", NULL};
143        char *file;
144        int i;
145    
146        for (i=0; files[i] != NULL; i++) {
147            file = make_filename (homedir, files[i], NULL);
148            remove_crit_file_attrs (file, 0);
149          free_if_alloc (file);          free_if_alloc (file);
150      }      }
151  }  }
152    
153    
154    /* Load the GPG environment. On the first start, some
155       checks are performed to find out in what state GPG is.
156       Return value: 0  everything OK.
157                     >0  fatal error.
158                     -1 public keyring is empty or does not exist. */
159    static int
160    load_gpg_env (void)
161    {
162        SECURITY_ATTRIBUTES sec_attr;
163        char *p;
164        char *pkr;
165    
166        p = get_reg_entry_gpg4win ("gpg.exe");
167        if (!p)
168            return (1);
169        if (file_exist_check (p)) {
170            free_if_alloc (p);
171            return (1);
172        }
173        free_if_alloc (p);
174    
175        p = get_reg_entry_gpg ("HomeDir");
176        if (!p || dir_exist_check (p) != 0) {
177            free_if_alloc (p);
178            p = multi_gnupg_path (0);
179        }
180        if (p && dir_exist_check (p)) {
181            memset (&sec_attr, 0, sizeof (sec_attr));
182            sec_attr.nLength = sizeof (sec_attr);
183            if (!CreateDirectory (p, &sec_attr)) {
184                msg_box (NULL, _("Could not create GPG home directory"),
185                         _("WinPT Error"), MB_ERR);
186                free_if_alloc (p);
187                return (2);
188            }
189        }
190        check_readonly_attr (p);
191        pkr = make_filename (p, "pubring", "gpg");
192        free_if_alloc (p);
193        if (!pkr)
194            return -1;
195        if (get_file_size (pkr) == 0) {
196            free_if_alloc (pkr);
197            return -1;
198        }
199        return 0;
200    }
201    
202    
203  /* check if the default key from the gpg.conf file is available in the  /* check if the default key from the gpg.conf file is available in the
204     keyring. if not, bail out because encryption won't work properly then. */     keyring. if not, bail out because encryption won't work properly then. */
205  static int  static int
# Line 121  check_default_key (gpg_keycache_t kc) Line 207  check_default_key (gpg_keycache_t kc)
207  {  {
208      gpgme_key_t key;      gpgme_key_t key;
209      gpgme_error_t err = GPG_ERR_NO_ERROR;      gpgme_error_t err = GPG_ERR_NO_ERROR;
210      char * defkey;      char *defkey;
211    
212      defkey = get_gnupg_default_key ();      defkey = get_gnupg_default_key ();
213      if (defkey)      if (defkey)
214          err = gpg_keycache_find_key (kc, defkey, 0, &key);          err = gpg_keycache_find_key (kc, defkey, 0, &key);
215      else      else
216          msg_box (NULL, _("No useable secret key found."), _("WinPT Error"), MB_ERR);          msg_box (NULL, _("No useable secret key found."),
217                     _("WinPT Error"), MB_ERR);
218      free_if_alloc (defkey);      free_if_alloc (defkey);
219      return err? -1 : 0;      return err? -1 : 0;
220  }  }
221    
222    
223  /* Return the WinPT program file name (with full pathname). */  /* Return the WinPT program file name (with full pathname). */
224  static const char *  static const char*
225  get_prog_part (const char * fname, int use_cwd)  get_prog_part (const char * fname, int use_cwd)
226  {  {
227      static char program[512];      static char program[512];
# Line 168  get_prog_part (const char * fname, int u Line 255  get_prog_part (const char * fname, int u
255    
256  /* Check that the underlying crypto engine fullfills the minimal  /* Check that the underlying crypto engine fullfills the minimal
257     requirements so all commands work properly. */     requirements so all commands work properly. */
258  static int  static bool
259  check_crypto_engine (void)  check_crypto_engine (void)
260  {  {
261      int ma=1, mi=4, pa=2; /* GPG 1.4.2 */      int ma=0, mi=0, pa=0;
262      int rc;      int rc;
263    
264      rc = check_gnupg_engine (&ma, &mi, &pa);      rc = check_gnupg_engine (NEED_GPG_VERSION, &ma, &mi, &pa);
265      if (rc == -1) {      if (rc == -1) {
266          msg_box (NULL, _("Could not read GnuPG version."),          msg_box (NULL, _("Could not read GnuPG version."),
267                   _("WinPT Error"), MB_ERR);                   _("WinPT Error"), MB_ERR);
268          return rc;          return false;
269      }      }
270      else if (rc) {      else if (rc) {
271          log_box (_("WinPT Error"), MB_ERR,          log_box (_("WinPT Error"), MB_ERR,
272                   _("Sorry, you need a newer GPG version.\n"                   _("Sorry, you need a newer GPG version.\n"
273                     "GPG version %d.%d.%d required GPG version "MIN_GPG_VER),                     "GPG version %d.%d.%d required GPG version "NEED_GPG_VERSION),
274                     ma, mi, pa);                     ma, mi, pa);
275          return rc;          return false;
276      }      }
277      /* We enable smartcard support for GPG: >= 2 or >= 1.4.3 */      /* We enable smartcard support for GPG: >= 2 or >= 1.4.3 */
278      if (ma > 1 || pa >= 3)      if (ma > 1 || pa >= 3)    
279          scard_support = 1;          scard_support = 1;
280    
281      gpgver[0] = ma;      gpgver[0] = ma;
282      gpgver[1] = mi;      gpgver[1] = mi;
283      gpgver[2] = pa;      gpgver[2] = pa;
284      return rc;      return true;
285  }  }
286    
287    
# Line 203  check_crypto_engine (void) Line 290  check_crypto_engine (void)
290  static int  static int
291  load_keyserver_conf (int quiet)  load_keyserver_conf (int quiet)
292  {  {
293      const char * t;      char *buf;
294        const char *t;
295      int rc;      int rc;
296    
297      if (reg_prefs.kserv_conf)      /* Create $APPDATA\winpt if needed. */
298          t = reg_prefs.kserv_conf;      buf = make_special_filename (CSIDL_APPDATA, "winpt", NULL);
299      else if (!file_exist_check (get_prog_part ("keyserver.conf", 0)))      if (buf && dir_exist_check (buf) && !CreateDirectory (buf, NULL)) {
300            MessageBox (NULL, _("Failed to create WinPT directory"),
301                        _("Keyserver"), MB_ERR);
302            free_if_alloc (buf);
303            return -1;
304        }
305        free_if_alloc (buf);
306    
307        /* Check for $APPDATA\winpt\keyserver.conf */
308        buf = make_special_filename (CSIDL_APPDATA, "winpt\\keyserver.conf", NULL);
309    
310        if (!file_exist_check (get_prog_part ("keyserver.conf", 0)))
311          t = get_prog_part ("keyserver.conf", 0);          t = get_prog_part ("keyserver.conf", 0);
312      else      else
313          t = "keyserver.conf";          t = "keyserver.conf";
314        if (file_exist_check (t) == 0 && file_exist_check (buf) != 0) {
315            //log_box (_("Keyserver"), MB_INFO,
316            //       _("keyserver.conf will be copied to \"%s\"\r\n"), buf);
317            if (!CopyFile (t, buf, FALSE)) {
318                MessageBox (NULL, _("Failed to copy the keyserver.conf"),
319                            _("Keyserver"), MB_ERR);
320                free_if_alloc (buf);
321                return -1;
322            }
323            t = buf;
324        }
325        else
326            t = buf;
327        
328      rc = kserver_load_conf (t);      rc = kserver_load_conf (t);
329      if (rc && !quiet)      if (rc && !quiet)
330          msg_box (NULL, winpt_strerror (rc), _("Keyserver"), MB_ERR);          msg_box (NULL, winpt_strerror (rc), _("Keyserver"), MB_ERR);
331        else {
332            free_if_alloc (reg_prefs.kserv_conf);
333            reg_prefs.kserv_conf = m_strdup (t);
334        }
335        free_if_alloc (buf);
336      return rc;      return rc;
337  }  }
338    
339    
340    /* Check if both keyrings are empty. This indicates that
341       WinPT should offer to generate a key pair. */
342    static bool
343    check_for_empty_keyrings (bool pub_only)
344    {
345        char *p;
346        int n = 0;
347    
348        p = get_gnupg_keyring (1, 0);
349        if (file_exist_check (p) == 0 && get_file_size (p) == 0)
350            n++;
351        free_if_alloc (p);
352        if (pub_only)
353            return n == 1? true : false;
354        p = get_gnupg_keyring (0, 0);
355        if (file_exist_check (p) == 0 && get_file_size (p) == 0)
356            n++;
357        free_if_alloc (p);
358        return n==2? true : false;
359    }
360    
361    
362  /* Enable the mobility mode. */  /* Enable the mobility mode. */
363  static void  static void
364  enable_mobile_mode (void)  enable_mobile_mode (void)
# Line 236  enable_mobile_mode (void) Line 376  enable_mobile_mode (void)
376      reg_prefs.use_viewer = 0; /* XXX */      reg_prefs.use_viewer = 0; /* XXX */
377  }  }
378    
 char* multi_gnupg_path (void);  
   
 const char * fm_get_file_type (const char *fname, int *r_type);  
379    
380  /* Main entry point. */  /* Main entry point. */
381  int WINAPI  int WINAPI
# Line 246  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 383  WinMain (HINSTANCE hinst, HINSTANCE hpre
383  {  {
384      WNDCLASS wc = {0, winpt_main_proc, 0, 0, hinst, 0, 0, 0, 0, PGM_NAME};      WNDCLASS wc = {0, winpt_main_proc, 0, 0, hinst, 0, 0, 0, 0, PGM_NAME};
385      HACCEL accel_tab;      HACCEL accel_tab;
386      int rc, ec, created = 0, nfiles = 0;      MSG msg;
387        HWND hwnd = NULL;
388        WORD ver[3], ptdver[4];
389        int rc, ec, created = 0;
390      int first_start = 0, start_gpgprefs = 0;      int first_start = 0, start_gpgprefs = 0;
391      int winpt_inst_found = 0;      int winpt_inst_found = 0;
392        int start_manager = 0;
393      const char *s;      const char *s;
     MSG msg;  
     HWND hwnd = NULL;  
394    
395      glob_hinst = hinst;      glob_hinst = hinst;
396        if (cmdline && stristr (cmdline, "--stop")) {
397            hwnd = FindWindow ("WinPT", "WinPT");
398            if (hwnd != NULL)
399                PostMessage (hwnd, WM_DESTROY, 0, 0);
400            return 0;
401        }
402    
403        /*
404        OSVERSIONINFO osinf;
405        memset (&osinf, 0, sizeof (osinf));
406        if (GetVersionEx (&osinf) &&
407            osinf.dwPlatformId == VER_PLATFORM_WIN32_WINDOWS &&
408            osinf.dwMinorVersion == 0) {
409            msg_box (NULL, "WinPT propably does not work on Windows 95 without restrictions",
410                     "WinPT Warning", MB_INFO);
411        }
412        */
413    
414  #ifdef _DEBUG      #ifdef _DEBUG
415      gpg_set_debug_mode (1);      gpg_set_debug_mode (1);
416      debug = 1;      debug = 1;
417  #endif      #endif
418    
419        get_file_version ("WinPT.exe", &ver[0], &ver[1], &ver[2], &ver[3]);
420        get_file_version ("PTD.dll", &ptdver[0], &ptdver[1],
421                                     &ptdver[2], &ptdver[3]);
422        /* XXX
423        if (ptdver[0] != ver[0] || ptdver[1] != ver[1]|| ptdver[2] != ver[2]) {
424            log_box (_("WinPT Error"), MB_ERR,
425                     _("The PTD.dll file has a different version than WinPT.exe\n"
426                       "Please update the PTD.dll to version %d.%d.%d"),
427                       ver[0], ver[1], ver[2]);
428            return 0;
429        }
430        */
431    
432      if (gpg_md_selftest ()) {      if (gpg_md_selftest ()) {
433          msg_box (NULL, _("Cryptographic selftest failed."),          msg_box (NULL, _("Cryptographic selftest failed."),
# Line 266  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 435  WinMain (HINSTANCE hinst, HINSTANCE hpre
435          return 0;          return 0;
436      }      }
437    
438      s = gpgme_check_version (MIN_GPGME_VER);      s = gpgme_check_version (NEED_GPGME_VERSION);
439      if (!s || !*s) {      if (!s || !*s) {
440          msg_box (NULL, _("A newer GPGME version is needed; at least "MIN_GPGME_VER),          msg_box (NULL, _("A newer GPGME version is needed; at least "NEED_GPGME_VERSION),
441                   _("WinPT Error"), MB_ERR);                   _("WinPT Error"), MB_ERR);
442          return 0;          return 0;
443      }      }
# Line 284  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 453  WinMain (HINSTANCE hinst, HINSTANCE hpre
453      }      }
454    
455      set_default_kserver ();      set_default_kserver ();
456        load_gettext (winpt_inst_found);
457    
458      if (!mobile) {      if (!mobile) {
459          regist_inst_gnupg (1);          regist_inst_gnupg (1);
# Line 304  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 474  WinMain (HINSTANCE hinst, HINSTANCE hpre
474              hotkeys_modify ();              hotkeys_modify ();
475          gnupg_load_config ();          gnupg_load_config ();
476      }      }
477        else { /* default settings. */
478            reg_prefs.keylist_mode = 1;
479        }
480    
481        if (is_gpg4win_installed ())
482            load_gpg_env (); /* XXX: check return code. */
483    
484      rc = gnupg_check_homedir ();      rc = gnupg_check_homedir ();
485      if (rc) {      if (rc) {
# Line 312  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 488  WinMain (HINSTANCE hinst, HINSTANCE hpre
488                     "Please check the GPG registry settings:\n%s."),                     "Please check the GPG registry settings:\n%s."),
489                   winpt_strerror (rc));                   winpt_strerror (rc));
490          s = get_fileopen_dlg (GetActiveWindow (),          s = get_fileopen_dlg (GetActiveWindow (),
491                                _("Select GPG Public Keyring"),                                _("Select GPG Public Keyring"),
492                                _("GPG Keyrings (*.gpg)\0*.gpg\0\0"),                                "GPG Keyrings (*.gpg)\0*.gpg\0\0",
493                                NULL);                                NULL);
494          if (s != NULL) {          if (s != NULL) {
495              size_t n;              size_t n;
496              char * p = strrchr (s, '\\');              char *p = strrchr (s, '\\');
497              if (!p)              if (!p)
498                  BUG (0);                  BUG (0);
499              n = p - s;              n = p - s;
500              if (n) {              if (n) {
501                  char * file = new char[n+1];                  char *file = new char[n+1];
502                  if (!file)                  if (!file)
503                      BUG (NULL);                      BUG (NULL);
504                  memset (file, 0, n);                  memset (file, 0, n);
# Line 347  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 523  WinMain (HINSTANCE hinst, HINSTANCE hpre
523                               "correct  this problem?"), _("WinPT Error"),                               "correct  this problem?"), _("WinPT Error"),
524                               MB_INFO|MB_YESNO) == IDYES)                               MB_INFO|MB_YESNO) == IDYES)
525              start_gpgprefs = 1;              start_gpgprefs = 1;
526          else          else {
         {  
527              msg_box (NULL, winpt_strerror (rc), _("WinPT Error"), MB_ERR);              msg_box (NULL, winpt_strerror (rc), _("WinPT Error"), MB_ERR);
528              return 0;              return 0;
529          }          }
# Line 370  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 545  WinMain (HINSTANCE hinst, HINSTANCE hpre
545              return 0;              return 0;
546          }          }
547      }      }
548        if (check_for_empty_keyrings (false))
549            first_start = 1;
550    
551      if (!first_start) {      if (!first_start) {
552          rc = gpg_check_permissions (1);          rc = gpg_check_permissions (1);
# Line 378  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 555  WinMain (HINSTANCE hinst, HINSTANCE hpre
555          else if (rc)          else if (rc)
556              return 0;              return 0;
557      }      }
558        
     load_gettext (winpt_inst_found);  
559      init_gnupg_table ();      init_gnupg_table ();
560    
561      nfiles = fm_parse_command_line (cmdline);      if (fm_parse_command_line (cmdline) > 0) {
     if (nfiles > 0) {  
562          free_gnupg_table ();          free_gnupg_table ();
563          return 0;          return 0;
564      }      }
# Line 400  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 575  WinMain (HINSTANCE hinst, HINSTANCE hpre
575    
576      if (cmdline && (stristr (cmdline, "--keymanager")      if (cmdline && (stristr (cmdline, "--keymanager")
577                  || stristr (cmdline, "--cardmanager"))) {                  || stristr (cmdline, "--cardmanager"))) {
578          update_keycache (GetDesktopWindow ());          /* If an instance of WinPT is running, just send the command
579               to open the key manager. Otherwise start a new instance.
580             */
581            HWND tray = FindWindow ("WinPT", "WinPT");
582          if (stristr (cmdline, "keymanager"))          if (stristr (cmdline, "keymanager"))
583              dialog_box_param (glob_hinst, (LPCTSTR)IDD_WINPT_KEYMISC,              start_manager = ID_WINPT_KEY;
584                              GetDesktopWindow(), keymanager_dlg_proc, 0,          else
585                              _("Key Manager"), IDS_WINPT_KEYMISC);                start_manager = ID_WINPT_CARD;
586          else {          if (tray != NULL) {
587              gpg_card_t crd = gpg_card_load ();              PostMessage (tray, WM_COMMAND, start_manager, 0);
588              if (crd)              free_gnupg_table ();
589                  dialog_box_param (glob_hinst, (LPCTSTR)IDD_WINPT_CARD_EDIT,              return 0;
                                   GetDesktopWindow(), card_edit_dlg_proc,  
                                   (LPARAM)crd, _("Card Manager"),  
                                   IDS_WINPT_CARD_EDIT);  
             gpg_card_release (crd);  
590          }          }
         keycache_release (0);  
         free_gnupg_table ();  
         return 0;  
591      }      }
592    
593      /* If we found another WinPT instance, just quit to avoid it      /* If we found another WinPT instance, just quit to avoid it
# Line 428  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 599  WinMain (HINSTANCE hinst, HINSTANCE hpre
599      }      }
600    
601      if (cmdline) {      if (cmdline) {
602          if (stristr (cmdline, "--enable-debug") || stristr (cmdline, "--debug")) {          if (stristr (cmdline, "--enable-debug") ||
603                stristr (cmdline, "--debug")) {
604              gpg_set_debug_mode (1);              gpg_set_debug_mode (1);
605              winpt_debug_msg ();              winpt_debug_msg ();
606              debug = 1;              debug = 1;
# Line 461  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 633  WinMain (HINSTANCE hinst, HINSTANCE hpre
633    
634      if (!first_start && !start_gpgprefs) {      if (!first_start && !start_gpgprefs) {
635          gnupg_backup_options ();                  gnupg_backup_options ();        
636          rc = check_crypto_engine ();          if (!check_crypto_engine ()) {
         if (rc) {  
637              DestroyWindow (hwnd);              DestroyWindow (hwnd);
638              free_gnupg_table ();              free_gnupg_table ();
639              return 0;              return 0;
# Line 470  WinMain (HINSTANCE hinst, HINSTANCE hpre Line 641  WinMain (HINSTANCE hinst, HINSTANCE hpre
641      }      }
642            
643      if (start_gpgprefs) {      if (start_gpgprefs) {
         char *ring;  
   
644          DialogBoxParam (glob_hinst, (LPCTSTR)IDD_WINPT_GPGPREFS, hwnd,          DialogBoxParam (glob_hinst, (LPCTSTR)IDD_WINPT_GPGPREFS, hwnd,
645                          gpgprefs_dlg_proc, 0);                          gpgprefs_dlg_proc, 0);
646          ring = get_gnupg_keyring (0, !NO_STRICT);          if (check_for_empty_keyrings (true))
647          if (gnupg_access_keyring (0) == -1 && get_file_size (ring) == 0)              first_start = 1; /* The public keyring is empty! */
             first_start = 1; /* The keyring is empty! */  
         free_if_alloc (ring);  
648      }      }
649    
650      if (first_start) {      if (first_start) {
         struct first_start_s fs;  
651          struct genkey_s c;          struct genkey_s c;
652            int choice;
653          HWND h;          HWND h;
654  start:  start:
655          h = GetDesktopWindow ();          h = GetDesktopWindow ();
656          DialogBoxParam (glob_hinst, (LPCTSTR)IDD_WINPT_GPGPREFS, h,          if (!gpg_prefs_ok ())
657                DialogBoxParam (glob_hinst, (LPCTSTR)IDD_WINPT_GPGPREFS, h,
658                              gpgprefs_dlg_proc, 0);                              gpgprefs_dlg_proc, 0);
659          DialogBoxParam (glob_hinst, (LPCSTR)IDD_WINPT_FIRST, h,          choice = DialogBoxParam (glob_hinst, (LPCSTR)IDD_WINPT_FIRST, h,
660                          first_run_dlg_proc, (LPARAM)&fs);                                   first_run_dlg_proc, 0);
661          switch (fs.choice) {          switch (choice) {
662          case SETUP_KEYGEN:          case SETUP_KEYGEN:
663              c.interactive = 1;              c.interactive = 1;
664              c.first_start = 1;              c.first_start = 1;
# Line 508  start: Line 676  start:
676              }              }
677              break;              break;
678    
679          case -1:          case 0: /* Cancel/Abort. */
680            default:
681              DestroyWindow (hwnd);              DestroyWindow (hwnd);
682              free_gnupg_table ();              free_gnupg_table ();
683              return 0;              return 0;
684          }          }
685          update_keycache (hwnd);          update_keycache (hwnd);
686          check_crypto_engine ();          if (!check_crypto_engine ()) {
687                DestroyWindow (hwnd);
688                free_gnupg_table ();
689                return 0;
690            }
691      }      }
692      else {      else {
693          gpg_keycache_t c;          gpg_keycache_t c;
# Line 540  start: Line 713  start:
713              }              }
714          }          }
715          if (check_default_key (c)) {          if (check_default_key (c)) {
716              char * p = get_gnupg_default_key ();              char *p = get_gnupg_default_key ();
717              log_box (_("WinPT Error"), MB_ERR,              log_box (_("WinPT Error"), MB_ERR,
718                       _("Default key from the GPG options file could not be found.\n"                       _("Default key from the GPG options file could not be found.\n"
719                         "Please check your gpg.conf (options) to correct this:\n\n"                         "Please check your gpg.conf (options) to correct this:\n\n"
# Line 555  start: Line 728  start:
728                              elgamal_warn_dlg_proc, 0);                              elgamal_warn_dlg_proc, 0);
729      }      }
730    
731        if (start_manager)
732            PostMessage (hwnd, WM_COMMAND, start_manager, 0);
733    
734      accel_tab = LoadAccelerators (glob_hinst, (LPCTSTR)IDR_WINPT_ACCELERATOR);      accel_tab = LoadAccelerators (glob_hinst, (LPCTSTR)IDR_WINPT_ACCELERATOR);
735      keyring_check_last_access (); /* init */      keyring_check_last_access (); /* init */
736      while (GetMessage (&msg, hwnd, 0, 0)) {      while (GetMessage (&msg, hwnd, 0, 0)) {

Legend:
Removed from v.80  
changed lines
  Added in v.172

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26