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

Diff of /trunk/Src/wptKeyManagerDlg.cpp

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

revision 205 by twoaday, Thu Apr 27 12:46:03 2006 UTC revision 218 by twoaday, Wed May 24 07:53:24 2006 UTC
# Line 63  Line 63 
63    
64  static subclass_s keylist_proc;  static subclass_s keylist_proc;
65    
66    /* Handle to the global image list. */
67  HIMAGELIST glob_imagelist;  HIMAGELIST glob_imagelist;
68    
69  struct km_info_s {  struct km_info_s {
# Line 71  struct km_info_s { Line 72  struct km_info_s {
72      int ypos_sep;      int ypos_sep;
73      int ypercent_sep;      int ypercent_sep;
74    
75        /* Different kind of windows. */
76      HWND dlg;      HWND dlg;
77      HWND hwnd_sep;      HWND hwnd_sep;
78      HWND toolbar;      HWND toolbar;
# Line 79  struct km_info_s { Line 81  struct km_info_s {
81      listview_ctrl_t lv;      listview_ctrl_t lv;
82      int             lv_idx;      int             lv_idx;
83      int keylist_sortby;      int keylist_sortby;
84        int magic;
85    
86        unsigned int enable_groups:1;
87  };  };
88    typedef struct km_info_s *km_info_t;
89    
90  /* Toolbar button structure. */  /* Toolbar button structure. */
91  struct mybuttons {  struct mybuttons {
# Line 99  struct mybuttons myb[] = { Line 105  struct mybuttons myb[] = {
105    
106  static void km_gui_import (struct km_info_s *kmi, int cmd_id, void *param);  static void km_gui_import (struct km_info_s *kmi, int cmd_id, void *param);
107    
108    
109  /* Subclass the keylist listview control to allow extended commands. */  /* Subclass the keylist listview control to allow extended commands. */
110  static BOOL CALLBACK  static BOOL CALLBACK
111  keylist_subclass_proc (HWND dlg, UINT msg, WPARAM wparam, LPARAM lparam)  keylist_subclass_proc (HWND dlg, UINT msg, WPARAM wparam, LPARAM lparam)
# Line 208  load_toolbar (HWND dlg, struct km_info_s Line 215  load_toolbar (HWND dlg, struct km_info_s
215  /* Restore the width of the columns from the registry.  /* Restore the width of the columns from the registry.
216     If no bitstring was found, the default size is used. */     If no bitstring was found, the default size is used. */
217  int  int
218  restore_column_info (listview_ctrl_t hd)  restore_column_info (struct km_info_s *kmi)
219  {  {
220      WORD *buf;      WORD *buf;
221      HKEY root;      HKEY root;
222      DWORD type;      DWORD type;
223      DWORD size = hd->cols*sizeof (WORD), i;      DWORD size = kmi->lv->cols*sizeof (WORD), i;
224      LONG ec;      LONG ec;
225    
226      ec = RegOpenKeyEx (HKEY_CURRENT_USER, "Software\\WinPT", 0,      ec = RegOpenKeyEx (HKEY_CURRENT_USER, "Software\\WinPT", 0,
# Line 225  restore_column_info (listview_ctrl_t hd) Line 232  restore_column_info (listview_ctrl_t hd)
232      if (!buf)      if (!buf)
233          BUG (NULL);          BUG (NULL);
234      ec = RegQueryValueEx (root, "KMColumnSize", NULL, &type,      ec = RegQueryValueEx (root, "KMColumnSize", NULL, &type,
235                            (BYTE*)buf, &size);                            (BYTE*)buf, &size);    
     RegCloseKey (root);  
236      if (ec != ERROR_SUCCESS) {      if (ec != ERROR_SUCCESS) {
237            RegCloseKey (root);
238          free_if_alloc (buf);          free_if_alloc (buf);
239          return -1;          return -1;
240      }      }
# Line 240  restore_column_info (listview_ctrl_t hd) Line 247  restore_column_info (listview_ctrl_t hd)
247          }          }
248      }      }
249      for (i=0; i < size/2; i++)      for (i=0; i < size/2; i++)
250          listview_set_column_width (hd, i, buf[i]);          listview_set_column_width (kmi->lv, i, buf[i]);
251      free_if_alloc (buf);      free_if_alloc (buf);
252    
253        size = sizeof (kmi->keylist_sortby);
254        ec = RegQueryValueEx (root, "KMSortBy", NULL, &type,
255                              (BYTE*)&kmi->keylist_sortby, &size);
256        if (ec != ERROR_SUCCESS)
257            kmi->keylist_sortby = KEY_SORT_USERID;
258        RegCloseKey (root);
259      return 0;      return 0;
260  }  }
261    
262    
263  /* Save the current column width to the registry. */  /* Save the current column width to the registry. */
264  int  int
265  save_column_info (listview_ctrl_t hd)  save_column_info (struct km_info_s *kmi)
266  {  {    
     WORD *buf;  
267      HKEY root;      HKEY root;
268        WORD *buf;
269      LONG ec;      LONG ec;
270      int i;      int i;
271    
272      buf = new WORD[hd->cols];      buf = new WORD[kmi->lv->cols];
273      if (!buf)      if (!buf)
274          BUG (NULL);          BUG (NULL);
275      for (i=0; i < hd->cols; i++) {      for (i=0; i < kmi->lv->cols; i++) {
276          LVCOLUMN lvc;          LVCOLUMN lvc;
277    
278          memset (&lvc, 0, sizeof (lvc));          memset (&lvc, 0, sizeof (lvc));
279          lvc.mask = LVCF_WIDTH;          lvc.mask = LVCF_WIDTH;
280          ListView_GetColumn (hd->ctrl, i, &lvc);          ListView_GetColumn (kmi->lv->ctrl, i, &lvc);
281          buf[i] = lvc.cx;          buf[i] = lvc.cx;
282      }      }
283    
# Line 275  save_column_info (listview_ctrl_t hd) Line 289  save_column_info (listview_ctrl_t hd)
289      }      }
290    
291      ec = RegSetValueEx (root, "KMColumnSize", 0, REG_BINARY,      ec = RegSetValueEx (root, "KMColumnSize", 0, REG_BINARY,
292                          (const BYTE*)buf, 2*hd->cols);                          (const BYTE*)buf, 2*kmi->lv->cols);
293        if (ec == ERROR_SUCCESS) {
294            ec = RegSetValueEx (root, "KMSortBy", 0, REG_DWORD_BIG_ENDIAN,
295                                (const BYTE*)&kmi->keylist_sortby,
296                                sizeof (kmi->keylist_sortby));
297        }
298      RegCloseKey (root);      RegCloseKey (root);
299      free_if_alloc (buf);      free_if_alloc (buf);
300      return ec == ERROR_SUCCESS? 0 : -1;      return ec == ERROR_SUCCESS? 0 : -1;
# Line 385  do_resize_window (HWND dlg, struct km_in Line 404  do_resize_window (HWND dlg, struct km_in
404                  kmi->ypos_sep - rclient.top, bRepaint);                  kmi->ypos_sep - rclient.top, bRepaint);
405      rclient.top = kmi->ypos_sep + 5 + 8;      rclient.top = kmi->ypos_sep + 5 + 8;
406    
407  #if 0 /* Disable the code until we support groups again. */      if (kmi->enable_groups != 0) {
408      /* Place the group text and the group box below the separator */          /* Place the group text and the group box below the separator */
409      h = GetDlgItem (dlg, IDC_KEYMISC_GTEXT);          h = GetDlgItem (dlg, IDC_KEYMISC_GTEXT);
410      MoveWindow (h, rclient.left, rclient.top, 100, 14, bRepaint);          MoveWindow (h, rclient.left, rclient.top, 100, 14, bRepaint);
411      rclient.top += 18;          rclient.top += 18;
412    
413      h = GetDlgItem (dlg, IDC_KEYMISC_GROUP);          h = GetDlgItem (dlg, IDC_KEYMISC_GROUP);
414      MoveWindow (h, rclient.left, rclient.top, rclient.right - rclient.left,          MoveWindow (h, rclient.left, rclient.top,
415                  (rclient.bottom < rclient.top) ?                      rclient.right - rclient.left,
416                  0 : rclient.bottom - rclient.top, bRepaint);                      (rclient.bottom < rclient.top) ?
417  #endif                      0 : rclient.bottom - rclient.top, bRepaint);
418        }
419            
420      /* Repaint the whole thing */      /* Repaint the whole thing */
421      InvalidateRect (dlg, NULL, TRUE);      InvalidateRect (dlg, NULL, TRUE);
# Line 669  update_ui_items (HWND hwnd, listview_ctr Line 689  update_ui_items (HWND hwnd, listview_ctr
689      }      }
690    
691      /* Disable all secret-key functions when no secret key is available. */      /* Disable all secret-key functions when no secret key is available. */
692      {      if (!secret_key_available ()) {
693          gpg_keycache_t sec = keycache_get_ctx (0);          enable_button (tb_hwnd, ID_KEYMISC_SIGN, FALSE);
694          if (gpg_keycache_get_size (sec) == 0) {          set_menu_state (hmenu, ID_KEYMISC_SIGN, MF_GRAYED);
             enable_button (tb_hwnd, ID_KEYMISC_SIGN, FALSE);  
             set_menu_state (hmenu, ID_KEYMISC_SIGN, MF_GRAYED);  
         }  
695      }      }
696  }  }
697    
# Line 1046  refresh_keylist (struct km_info_s *kmi) Line 1063  refresh_keylist (struct km_info_s *kmi)
1063                  keylist_upd_key (kmi->lv, pos, ctx, ctx->key);                  keylist_upd_key (kmi->lv, pos, ctx, ctx->key);
1064          }          }
1065      }      }
1066      keylist_sort (kmi->lv, KEY_SORT_USERID);      keylist_sort (kmi->lv, kmi->keylist_sortby);
1067      update_status_bar (kmi->statbar, kmi->lv);      update_status_bar (kmi->statbar, kmi->lv);
1068      keyring_check_last_access ();      keyring_check_last_access ();
1069  }  }
1070    
1071    
1072    /* Reload the key cache. */
1073    static void
1074    keycache_reload (HWND dlg)
1075    {      
1076        refresh_cache_s rcs;
1077    
1078        memset (&rcs, 0, sizeof rcs);
1079        rcs.kr_reload = rcs.kr_update = 1;
1080        rcs.tr_update = 0;
1081        DialogBoxParam (glob_hinst, (LPCSTR)IDD_WINPT_KEYCACHE, dlg,                                        
1082                        keycache_dlg_proc, (LPARAM)&rcs);
1083    }
1084    
1085    
1086    /* Check if the secret keyring contains at least one
1087       key with ultimate trust.
1088       Return value: 0 on success. */
1089    int
1090    check_ultimate_trusted_key (gpg_keycache_t _sec)
1091    {
1092        struct keycache_s *n;
1093        int nkeys = 0;
1094    
1095        for (n = _sec->item; n; n = n->next) {
1096            if (n->pubpart &&
1097                n->pubpart->key->owner_trust == GPGME_VALIDITY_ULTIMATE)
1098                return 0;
1099            nkeys++;
1100        }
1101    
1102        /* if we do not have any secret keys, it does not make sense
1103           to return an error. */
1104        if (nkeys == 0)
1105            return 0;
1106        return -1;
1107    }
1108    
1109    
1110  static void  static void
1111  reload_keylist (struct km_info_s *kmi)  reload_keylist (struct km_info_s *kmi)
1112  {  {
1113        gpg_keycache_t c;
1114    
1115        c = keycache_get_ctx (1);
1116      keycache_reload (kmi->dlg);      keycache_reload (kmi->dlg);
1117      keylist_reload (kmi->lv, keycache_get_ctx (1),      keylist_reload (kmi->lv, c, KEYLIST_LIST, kmi->keylist_sortby);
                     KEYLIST_LIST, KEY_SORT_USERID);  
1118      update_status_bar (kmi->statbar, kmi->lv);      update_status_bar (kmi->statbar, kmi->lv);
1119      keyring_check_last_access ();      keyring_check_last_access ();
1120  }  }
# Line 1075  reload_keycache (struct km_info_s *kmi) Line 1132  reload_keycache (struct km_info_s *kmi)
1132      DialogBoxParam (glob_hinst, (LPCSTR)IDD_WINPT_KEYCACHE, kmi->dlg,      DialogBoxParam (glob_hinst, (LPCSTR)IDD_WINPT_KEYCACHE, kmi->dlg,
1133                      keycache_dlg_proc, (LPARAM)&rcs);                      keycache_dlg_proc, (LPARAM)&rcs);
1134      c = keycache_get_ctx (1);      c = keycache_get_ctx (1);
1135      if (!c)      keylist_reload (kmi->lv, c, KEYLIST_LIST, kmi->keylist_sortby);
         BUG (0);  
     keylist_reload (kmi->lv, c, KEYLIST_LIST, KEY_SORT_USERID);  
1136      update_status_bar (kmi->statbar, kmi->lv);      update_status_bar (kmi->statbar, kmi->lv);
1137      SetForegroundWindow (kmi->dlg);      SetForegroundWindow (kmi->dlg);
1138  }  }
# Line 1115  km_gui_import (struct km_info_s *kmi, in Line 1170  km_gui_import (struct km_info_s *kmi, in
1170          reload_keylist (kmi);          reload_keylist (kmi);
1171    
1172      SetForegroundWindow (kmi->dlg);      SetForegroundWindow (kmi->dlg);
     center_window (kmi->dlg, NULL);  
1173  }  }
1174    
1175    
# Line 1123  km_gui_import (struct km_info_s *kmi, in Line 1177  km_gui_import (struct km_info_s *kmi, in
1177  BOOL CALLBACK  BOOL CALLBACK
1178  keymanager_dlg_proc (HWND dlg, UINT msg, WPARAM wparam, LPARAM lparam)  keymanager_dlg_proc (HWND dlg, UINT msg, WPARAM wparam, LPARAM lparam)
1179  {  {
     struct km_info_s *kmi = NULL;  
1180      HWND kl;      HWND kl;
1181      HMENU hm;      HMENU hm;
     struct keycache_s *kci;  
1182      gpg_keycache_t c;      gpg_keycache_t c;
1183      gpgme_key_t key;      gpgme_key_t key;
1184        struct keycache_s *kci;
1185        km_info_t kmi = NULL;    
1186      struct genkey_s genkey;      struct genkey_s genkey;
1187      struct winpt_key_s k = {0};      struct winpt_key_s k = {0};
1188      struct URL_ctx_s *url;      struct URL_ctx_s *url;
# Line 1138  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1192  keymanager_dlg_proc (HWND dlg, UINT msg,
1192      int l_idx = 0, i=0, rc;      int l_idx = 0, i=0, rc;
1193    
1194      if ((msg != WM_INITDIALOG)      if ((msg != WM_INITDIALOG)
1195          && ((kmi = (struct km_info_s*)GetWindowLong (dlg, GWL_USERDATA)) == NULL))          && ((kmi = (km_info_t)GetWindowLong (dlg, GWL_USERDATA)) == NULL))
1196          return FALSE;          return FALSE;
1197            
1198      /* handle dynamic popup items in the keyserver menu. */      /* handle dynamic popup items in the keyserver menu. */
# Line 1171  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1225  keymanager_dlg_proc (HWND dlg, UINT msg,
1225          Header_SetImageList(ListView_GetHeader (kl), glob_imagelist);          Header_SetImageList(ListView_GetHeader (kl), glob_imagelist);
1226          kmi->lv = keylist_load (GetDlgItem (dlg, IDC_KEYMISC_KEYLIST), c,          kmi->lv = keylist_load (GetDlgItem (dlg, IDC_KEYMISC_KEYLIST), c,
1227                                  NULL, KEYLIST_LIST, kmi->keylist_sortby);                                  NULL, KEYLIST_LIST, kmi->keylist_sortby);
1228          if (check_ultimate_trusted_key ()) {          if (check_ultimate_trusted_key (keycache_get_ctx (0))) {
1229              msg_box (dlg, _("No ultimately trusted key found.\n"              msg_box (dlg, _("No ultimately trusted key found.\n"
1230                              "Please set at least one secret key to ultimate trust."),                              "Please set at least one secret key to ultimate trust."),
1231                              _("Key Manager"), MB_WARN);                              _("Key Manager"), MB_WARN);
# Line 1196  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1250  keymanager_dlg_proc (HWND dlg, UINT msg,
1250          do_center_window (dlg, kmi);          do_center_window (dlg, kmi);
1251          do_resize_window (dlg, kmi);          do_resize_window (dlg, kmi);
1252          update_ui_items (dlg, kmi->lv);          update_ui_items (dlg, kmi->lv);
1253          restore_column_info (kmi->lv);          restore_column_info (kmi);
1254            keylist_sort (kmi->lv, kmi->keylist_sortby);
1255    
1256          SetDlgItemText (dlg, IDC_KEYMISC_GTEXT, _("Groups"));          SetDlgItemText (dlg, IDC_KEYMISC_GTEXT, _("Groups"));
1257            SetDlgItemText (dlg, ID_GROUP_SHOW, _("&Show"));
1258            SetDlgItemText (dlg, ID_GROUP_NEW, _("&New..."));
1259          SetClassLong (dlg, GCL_HICON, (LONG)LoadIcon (glob_hinst,          SetClassLong (dlg, GCL_HICON, (LONG)LoadIcon (glob_hinst,
1260                        (LPCTSTR)IDI_WINPT));                        (LPCTSTR)IDI_WINPT));
1261          SetForegroundWindow (dlg);          SetForegroundWindow (dlg);
1262          force_foreground_window (dlg, 1000);          kmi->magic = SetTimer (dlg, 1, 1000, NULL);
1263          return TRUE;          return TRUE;
1264    
1265        case WM_TIMER:
1266            KillTimer (dlg, kmi->magic);
1267            SetForegroundWindow (dlg);
1268            break;
1269                    
1270      case WM_DESTROY:      case WM_DESTROY:
1271          save_column_info (kmi->lv);          save_column_info (kmi);
1272          if (kmi->lv) {          if (kmi->lv) {
1273              keylist_delete (kmi->lv);              keylist_delete (kmi->lv);
1274              kmi->lv = NULL;                    kmi->lv = NULL;      
# Line 1220  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1282  keymanager_dlg_proc (HWND dlg, UINT msg,
1282          /* XXX: store window size. */          /* XXX: store window size. */
1283                    
1284          /* Remove runtime information. This should be the last action taken here. */          /* Remove runtime information. This should be the last action taken here. */
1285          delete kmi; kmi = NULL;          delete kmi;
1286            kmi = NULL;
1287          SetWindowLong (dlg, GWL_USERDATA, 0);          SetWindowLong (dlg, GWL_USERDATA, 0);
1288          return FALSE;          return FALSE;
1289    
     case WM_SHOWWINDOW:  
         break;  
   
1290      case WM_MOVE:      case WM_MOVE:
1291          RECT r;          RECT r;
1292          GetWindowRect (dlg, &r);          GetWindowRect (dlg, &r);
# Line 1387  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1447  keymanager_dlg_proc (HWND dlg, UINT msg,
1447                      set_menu_state (popup, ID_KEYCTX_PASTE, MF_DISABLED|MF_GRAYED);                      set_menu_state (popup, ID_KEYCTX_PASTE, MF_DISABLED|MF_GRAYED);
1448                  if (mapi_init ())                  if (mapi_init ())
1449                      set_menu_state (popup, ID_KEYCTX_SENDMAIL, MF_DISABLED|MF_GRAYED);                      set_menu_state (popup, ID_KEYCTX_SENDMAIL, MF_DISABLED|MF_GRAYED);
1450                    if (!secret_key_available ())
1451                        set_menu_state (popup, ID_KEYCTX_SIGN, MF_DISABLED|MF_GRAYED);
1452    
1453                  /* Override 'Default Keyserver' with the actual name. */                  /* Override 'Default Keyserver' with the actual name. */
1454                  host = kserver_get_hostname (0, -1, &port);                  host = kserver_get_hostname (0, -1, &port);
# Line 1562  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1624  keymanager_dlg_proc (HWND dlg, UINT msg,
1624                                _("Key Signature List"), IDS_WINPT_KEYSIG);                                _("Key Signature List"), IDS_WINPT_KEYSIG);
1625              if (k.update)              if (k.update)
1626                  update_key (kmi->lv, kmi->lv_idx, k.tmp_keyid, 0);                  update_key (kmi->lv, kmi->lv_idx, k.tmp_keyid, 0);
1627                if (updated_keys_avail ())
1628                    refresh_keylist (kmi);
1629              return TRUE;              return TRUE;
1630                            
1631          case ID_KEYMISC_PROPS:                case ID_KEYMISC_PROPS:      
# Line 1777  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1841  keymanager_dlg_proc (HWND dlg, UINT msg,
1841                  listview_select_all (kmi->lv);                  listview_select_all (kmi->lv);
1842              }              }
1843              km_refresh_from_keyserver (kmi->lv, dlg);              km_refresh_from_keyserver (kmi->lv, dlg);
1844                msg_box (dlg, _("Keyserver refresh finished."),
1845                         _("Key Manager"), MB_OK);
1846              break;              break;
1847                                                    
1848          /** Context menu **/          /** Context menu **/
# Line 1857  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1923  keymanager_dlg_proc (HWND dlg, UINT msg,
1923    
1924          case ID_KEYCTX_KEYID_COPY:          case ID_KEYCTX_KEYID_COPY:
1925              key = km_get_key_ptr (kmi->lv, kmi->lv_idx, NULL);              key = km_get_key_ptr (kmi->lv, kmi->lv_idx, NULL);
1926              set_clip_text (NULL, key->subkeys->keyid+8,              memset (type, 0, sizeof (type));
1927                             strlen (key->subkeys->keyid+8));              type[0] = '0'; type[1] = 'x';
1928                memcpy (type+2, key->subkeys->keyid+8, 8);
1929                set_clip_text (NULL, type, strlen (type));
1930              break;              break;
1931    
1932          case ID_KEYCTX_FPR_COPY:          case ID_KEYCTX_FPR_COPY:
# Line 1927  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1995  keymanager_dlg_proc (HWND dlg, UINT msg,
1995          case ID_GROUP_NEW:          case ID_GROUP_NEW:
1996          case ID_GROUP_PASTE:          case ID_GROUP_PASTE:
1997          case ID_GROUP_DELETE:          case ID_GROUP_DELETE:
1998            case ID_GROUP_SHOW:
1999              /* XXX: Implement group manager. */              /* XXX: Implement group manager. */
2000              return TRUE;              return TRUE;
2001    
2002                /*
2003          case IDCANCEL:          case IDCANCEL:
2004              EndDialog (dlg, TRUE);              EndDialog (dlg, TRUE);
2005              return TRUE;              return TRUE;
2006                */
2007          }          }
2008                    
2009          break;          break;

Legend:
Removed from v.205  
changed lines
  Added in v.218

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26