/[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 149 by twoaday, Fri Jan 13 14:21:16 2006 UTC revision 150 by twoaday, Wed Jan 18 11:52:45 2006 UTC
# Line 1  Line 1 
1  /* wptKeyManagerDlg.cpp - WinPT Key Manager  /* wptKeyManagerDlg.cpp - WinPT Key Manager
2   *      Copyright (C) 2000-2005 Timo Schulz   *      Copyright (C) 2000-2006 Timo Schulz
3   *      Copyright (C) 2004 Andreas Jobs   *      Copyright (C) 2004 Andreas Jobs
4   *   *
5   * This file is part of WinPT.   * This file is part of WinPT.
# Line 137  keylist_subclass_proc (HWND dlg, UINT ms Line 137  keylist_subclass_proc (HWND dlg, UINT ms
137              break;              break;
138    
139          case VK_P:          case VK_P:
140              if (GetAsyncKeyState (VK_CONTROL))                        if (GetAsyncKeyState (VK_CONTROL))
141                  km_clip_import (keylist_proc.dlg);                  send_cmd_id (keylist_proc.dlg, ID_KEYMISC_PASTE);
142              break;              break;
143    
144          case VK_F:          case VK_F:
# Line 382  do_resize_window (HWND dlg, struct km_in Line 382  do_resize_window (HWND dlg, struct km_in
382                  kmi->ypos_sep - rclient.top, bRepaint);                  kmi->ypos_sep - rclient.top, bRepaint);
383      rclient.top = kmi->ypos_sep + 5 + 8;      rclient.top = kmi->ypos_sep + 5 + 8;
384    
385    #if 0 /* Disable the code until we support groups again. */
386      /* Place the group text and the group box below the separator */      /* Place the group text and the group box below the separator */
387      h = GetDlgItem (dlg, IDC_KEYMISC_GTEXT);      h = GetDlgItem (dlg, IDC_KEYMISC_GTEXT);
388      MoveWindow (h, rclient.left, rclient.top, 100, 14, bRepaint);      MoveWindow (h, rclient.left, rclient.top, 100, 14, bRepaint);
# Line 391  do_resize_window (HWND dlg, struct km_in Line 392  do_resize_window (HWND dlg, struct km_in
392      MoveWindow (h, rclient.left, rclient.top, rclient.right - rclient.left,      MoveWindow (h, rclient.left, rclient.top, rclient.right - rclient.left,
393                  (rclient.bottom < rclient.top) ?                  (rclient.bottom < rclient.top) ?
394                  0 : rclient.bottom - rclient.top, bRepaint);                  0 : rclient.bottom - rclient.top, bRepaint);
395    #endif
396            
397      /* Repaint the whole thing */      /* Repaint the whole thing */
398      InvalidateRect (dlg, NULL, TRUE);      InvalidateRect (dlg, NULL, TRUE);
# Line 488  update_status_bar (HWND sb, listview_ctr Line 490  update_status_bar (HWND sb, listview_ctr
490  }  }
491    
492    
   
 /* Reload the key cache if requested. */  
 static void  
 do_check_cache (listview_ctrl_t lv, HWND dlg, HWND sb)  
 {  
     gpg_keycache_t cache;  
   
     if (keycache_get_reload ()) {  
         keycache_reload (dlg);  
         keycache_set_reload (0);  
         cache = keycache_get_ctx (1);  
         if (!cache)  
             BUG (dlg);  
         keylist_reload (lv, cache, KEYLIST_LIST, KEY_SORT_USERID);  
         update_status_bar (sb, lv);  
     }  
 }  
   
   
493  long CALLBACK  long CALLBACK
494  separator_wnd_proc (HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam)  separator_wnd_proc (HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam)
495  {  {
# Line 669  update_ui_items (HWND hwnd, listview_ctr Line 652  update_ui_items (HWND hwnd, listview_ctr
652      enable_button (tb_hwnd, ID_KEYMISC_SIGN, key_selected && !key_inv);      enable_button (tb_hwnd, ID_KEYMISC_SIGN, key_selected && !key_inv);
653      enable_button (tb_hwnd, ID_KEYMISC_EXPORT, key_selected);      enable_button (tb_hwnd, ID_KEYMISC_EXPORT, key_selected);
654      enable_button (tb_hwnd, ID_KEYCTX_COPY, key_selected);      enable_button (tb_hwnd, ID_KEYCTX_COPY, key_selected);
655        enable_button (tb_hwnd, ID_KEYCTX_PASTE, clip_contains_pgpkey ());
656    
657      /* Enable / disable menu items */      /* Enable / disable menu items */
658      state = key_selected? MF_ENABLED : MF_DISABLED|MF_GRAYED;      state = key_selected? MF_ENABLED : MF_DISABLED|MF_GRAYED;
# Line 1015  translate_popupmenu_strings (HMENU popup Line 999  translate_popupmenu_strings (HMENU popup
999  }  }
1000    
1001    
1002  /* Add all recently updated keys in the cache to the list. */  /* Return true if the cache contain marked keys. */
1003    static bool
1004    updated_keys_avail (void)
1005    {
1006        gpg_keycache_t kc = keycache_get_ctx (1);
1007        struct keycache_s *k;
1008    
1009        for (k = kc->item; k; k = k->next) {
1010            if (k->flags)
1011                return true;
1012        }
1013        return false;
1014    }
1015    
1016    
1017    /* Find the index of the key identified by @key. */
1018    static int
1019    find_keypos (listview_ctrl_t lv, gpgme_key_t key)
1020    {
1021        gpgme_key_t src;
1022        int i;
1023    
1024        for (i=0; i < listview_count_items (lv, 0); i++) {
1025            src = (gpgme_key_t)listview_get_item2 (lv, i);
1026            if (src && src->subkeys->keyid == key->subkeys->keyid)
1027                return i;
1028        }
1029        return -1;
1030    }
1031    
1032    
1033    /* Add all recently updated keys in the cache to the list
1034       and refresh all GUI elements. */
1035  static void  static void
1036  refresh_keylist (listview_ctrl_t lv)  refresh_keylist (struct km_info_s *kmi)
1037  {  {
1038      struct keycache_s *ctx;      struct keycache_s *ctx;
1039      gpg_keycache_t kc;      gpg_keycache_t kc;
1040        int status=0;
1041    
1042      kc = keycache_get_ctx (1);      kc = keycache_get_ctx (1);
1043      while (!gpg_keycache_next_updated_key (kc, &ctx)) {      while (!gpg_keycache_next_updated_key (kc, &ctx, &status)) {
1044          keylist_add_key (lv, KEYLIST_LIST, ctx->key);          if (status == KC_FLAG_ADD)
1045          /*msg_box (NULL, ctx->key->uids->name, "debug", MB_OK);*/              keylist_add_key (kmi->lv, KEYLIST_LIST, ctx->key);
1046            else
1047                keylist_upd_key (kmi->lv, find_keypos (kmi->lv, ctx->key), ctx->key);
1048            /*log_box ("debug", 0, "(%d) %s", status, ctx->key->uids->name);*/
1049      }      }
1050      keylist_sort (lv, KEY_SORT_USERID);      keylist_sort (kmi->lv, KEY_SORT_USERID);
1051        update_status_bar (kmi->statbar, kmi->lv);
1052  }  }
1053    
1054    
# Line 1036  BOOL CALLBACK Line 1057  BOOL CALLBACK
1057  keymanager_dlg_proc (HWND dlg, UINT msg, WPARAM wparam, LPARAM lparam)  keymanager_dlg_proc (HWND dlg, UINT msg, WPARAM wparam, LPARAM lparam)
1058  {  {
1059      struct km_info_s *kmi;      struct km_info_s *kmi;
     static int refresh_keys = 0;      
1060      INITCOMMONCONTROLSEX icex;      INITCOMMONCONTROLSEX icex;
1061      HWND kl;      HWND kl;
1062      HMENU hm;      HMENU hm;
# Line 1068  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1088  keymanager_dlg_proc (HWND dlg, UINT msg,
1088          translate_menu_strings (dlg);          translate_menu_strings (dlg);
1089          SetWindowText (dlg, _("Key Manager"));          SetWindowText (dlg, _("Key Manager"));
1090    
         if (keyring_check_last_access ())  
             keycache_set_reload (1);  
         if (keycache_get_reload ())  
             keycache_reload (dlg);  
1091          c = keycache_get_ctx (KEYCACHE_PUB);          c = keycache_get_ctx (KEYCACHE_PUB);
1092          if (!c)          if (!c)
1093              BUG (NULL);              BUG (NULL);
# Line 1123  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1139  keymanager_dlg_proc (HWND dlg, UINT msg,
1139          /* Remove runtime information. This should be the last action taken here. */          /* Remove runtime information. This should be the last action taken here. */
1140          delete kmi; kmi = NULL;          delete kmi; kmi = NULL;
1141          SetWindowLong (dlg, GWL_USERDATA, 0);          SetWindowLong (dlg, GWL_USERDATA, 0);
         keycache_set_reload (refresh_keys);  
1142          return FALSE;          return FALSE;
1143    
1144        case WM_SHOWWINDOW:
1145            /*refresh_keylist (kmi);*/
1146            break;
1147    
1148      case WM_MOVE:      case WM_MOVE:
1149          RECT r;          RECT r;
1150          GetWindowRect (dlg, &r);          GetWindowRect (dlg, &r);
# Line 1248  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1267  keymanager_dlg_proc (HWND dlg, UINT msg,
1267              if (notify->idFrom == IDC_KEYMISC_KEYLIST) {              if (notify->idFrom == IDC_KEYMISC_KEYLIST) {
1268                  l_idx =listview_get_curr_pos (kmi->lv);                  l_idx =listview_get_curr_pos (kmi->lv);
1269                  if (l_idx == -1)                  if (l_idx == -1)
1270                      return TRUE; /* Popup only when a item was selected */                      return TRUE; /* Popup only when a item was selected */              
                 do_check_cache (kmi->lv, dlg, kmi->statbar);  
1271                  GetCursorPos (&p);                  GetCursorPos (&p);
1272                  hm = LoadMenu (glob_hinst, MAKEINTRESOURCE (IDR_WINPT_KEYMISC_CTX));                  hm = LoadMenu (glob_hinst, MAKEINTRESOURCE (IDR_WINPT_KEYMISC_CTX));
1273                  popup = GetSubMenu (hm, 0);                  popup = GetSubMenu (hm, 0);
# Line 1362  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1380  keymanager_dlg_proc (HWND dlg, UINT msg,
1380                       _("Key Manager"), MB_ERR);                       _("Key Manager"), MB_ERR);
1381              return FALSE;              return FALSE;
1382          }          }
1383          do_check_cache (kmi->lv, dlg, kmi->statbar);  
1384          switch( LOWORD (wparam)) {          switch (LOWORD (wparam)) {
1385          case ID_KEYMISC_QUIT:          case ID_KEYMISC_QUIT:
1386              EndDialog (dlg, TRUE);              EndDialog (dlg, TRUE);
1387              return TRUE;              return TRUE;
               
         case ID_KEYMISC_MAIL:  
             /* XXX  
             DialogBoxParam (glob_hinst, (LPCTSTR)IDD_WINPT_MAIL, GetDesktopWindow (),  
                             winpt_mail_proc, NULL);*/  
             break;  
1388                    
1389          case ID_KEYMISC_FIND:          case ID_KEYMISC_FIND:
1390              km_find_key (dlg, kmi->lv);              km_find_key (dlg, kmi->lv);
# Line 1394  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1406  keymanager_dlg_proc (HWND dlg, UINT msg,
1406                  return TRUE;                  return TRUE;
1407              key = (gpgme_key_t)listview_get_item2 (kmi->lv, kmi->lv_idx);              key = (gpgme_key_t)listview_get_item2 (kmi->lv, kmi->lv_idx);
1408              memset (&k, 0, sizeof (k));              memset (&k, 0, sizeof (k));
1409                strncpy (k.tmp_keyid, key->subkeys->keyid+8, 8);
1410              k.ctx = key;              k.ctx = key;
1411              k.keyid = key->subkeys->keyid;              k.keyid = key->subkeys->keyid;
1412              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_KEYSIGN, dlg,              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_KEYSIGN, dlg,
1413                                keysign_dlg_proc, (LPARAM)&k,                                keysign_dlg_proc, (LPARAM)&k,
1414                                _("Key Signing"), IDS_WINPT_KEYSIGN);                                _("Key Signing"), IDS_WINPT_KEYSIGN);
1415              if (k.update)              if (k.update)
1416                  update_key (kmi->lv, kmi->lv_idx, k.keyid, 0);                  update_key (kmi->lv, kmi->lv_idx, k.tmp_keyid, 0);
1417              return TRUE;              return TRUE;
1418                            
1419          case ID_KEYMISC_REVCERT:          case ID_KEYMISC_REVCERT:
# Line 1465  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1478  keymanager_dlg_proc (HWND dlg, UINT msg,
1478              if (!key)              if (!key)
1479                  BUG (NULL);                  BUG (NULL);
1480              memset (&k, 0, sizeof (k));              memset (&k, 0, sizeof (k));
1481              k.keyid = key->subkeys->keyid+8;              strncpy (k.tmp_keyid, key->subkeys->keyid+8, 8);
1482                k.keyid = k.tmp_keyid;
1483              k.uid = key->uids->uid;              k.uid = key->uids->uid;
1484              k.ctx = (gpgme_key_t)listview_get_item2 (kmi->lv, kmi->lv_idx);              k.ctx = (gpgme_key_t)listview_get_item2 (kmi->lv, kmi->lv_idx);
1485              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_KEYSIG, dlg,              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_KEYSIG, dlg,
1486                                keysig_dlg_proc, (LPARAM)&k,                                keysig_dlg_proc, (LPARAM)&k,
1487                                _("Key Signature List" ), IDS_WINPT_KEYSIG);                                _("Key Signature List" ), IDS_WINPT_KEYSIG);
1488                if (k.update)
1489                    update_key (kmi->lv, kmi->lv_idx, k.tmp_keyid, 0);
1490              return TRUE;              return TRUE;
1491                            
1492          case ID_KEYMISC_PROPS:                case ID_KEYMISC_PROPS:      
# Line 1497  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1513  keymanager_dlg_proc (HWND dlg, UINT msg,
1513              return TRUE;              return TRUE;
1514                            
1515          case ID_KEYMISC_RECACHE:          case ID_KEYMISC_RECACHE:
1516              /* If there is already a reload request,              if (updated_keys_avail ())
                 don't bother the user with a message. */  
             if (keycache_get_reload () == 1)  
1517                  l_idx = IDYES;                  l_idx = IDYES;
1518              else {              else {
1519                  char inf[256];                  char inf[256];
# Line 1518  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1532  keymanager_dlg_proc (HWND dlg, UINT msg,
1532                  if (!c)                  if (!c)
1533                      BUG (dlg);                      BUG (dlg);
1534                  keylist_reload (kmi->lv, c, KEYLIST_LIST, KEY_SORT_USERID);                  keylist_reload (kmi->lv, c, KEYLIST_LIST, KEY_SORT_USERID);
                 refresh_keys = 0;  
1535              }              }
1536                SetForegroundWindow (dlg);
1537              return TRUE;              return TRUE;
1538                            
1539          case ID_KEYMISC_REBUILD:          case ID_KEYMISC_REBUILD:
# Line 1530  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1544  keymanager_dlg_proc (HWND dlg, UINT msg,
1544                  show_msg (dlg, 2000, line? name + (line-name)+1 : name);                  show_msg (dlg, 2000, line? name + (line-name)+1 : name);
1545                  safe_free (name);                  safe_free (name);
1546              }              }
1547                SetForegroundWindow (dlg);
1548              return TRUE;              return TRUE;
1549                            
1550          case ID_KEYMISC_NEWKEY:          case ID_KEYMISC_NEWKEY:
# Line 1537  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1552  keymanager_dlg_proc (HWND dlg, UINT msg,
1552              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_KEYGEN, dlg,              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_KEYGEN, dlg,
1553                                keygen_dlg_proc, (LPARAM)&genkey, _("Key Generation"),                                keygen_dlg_proc, (LPARAM)&genkey, _("Key Generation"),
1554                                IDS_WINPT_KEYGEN);                                IDS_WINPT_KEYGEN);
1555              if (genkey.newkey != NULL) {              if (genkey.cancel == 0)
1556                  keylist_add_key (kmi->lv, KEYLIST_LIST, genkey.newkey);                  refresh_keylist (kmi);
                 keylist_sort (kmi->lv, KEY_SORT_USERID);  
             }  
1557              return TRUE;              return TRUE;
1558    
1559          case ID_KEYMISC_CARDNEW:          case ID_KEYMISC_CARDNEW:
# Line 1552  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1565  keymanager_dlg_proc (HWND dlg, UINT msg,
1565              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_CARD_KEYGEN, dlg,              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_CARD_KEYGEN, dlg,
1566                                card_keygen_dlg_proc, 0, _("Card Key Generation"),                                card_keygen_dlg_proc, 0, _("Card Key Generation"),
1567                                IDS_WINPT_CARD_KEYGEN);                                IDS_WINPT_CARD_KEYGEN);
1568              /* XXX: use new code */              if (updated_keys_avail ())
             if (keycache_get_reload ())  
1569                  send_cmd_id (dlg, ID_KEYMISC_RECACHE);                  send_cmd_id (dlg, ID_KEYMISC_RECACHE);
1570              return TRUE;              return TRUE;
1571    
# Line 1563  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1575  keymanager_dlg_proc (HWND dlg, UINT msg,
1575                                keygen_wizard_dlg_proc, (LPARAM)&genkey,                                keygen_wizard_dlg_proc, (LPARAM)&genkey,
1576                                _("Key Generation Wizard"),                                _("Key Generation Wizard"),
1577                                IDS_WINPT_KEYWIZARD);                                IDS_WINPT_KEYWIZARD);
1578              if (genkey.newkey != NULL) {              if (genkey.cancel == 0)
1579                  keylist_add_key (kmi->lv, KEYLIST_LIST, genkey.newkey);                  refresh_keylist (kmi);
                 keylist_sort (kmi->lv, KEY_SORT_USERID);  
             }  
1580              return TRUE;              return TRUE;
1581                            
1582          case ID_KEYMISC_SENDRECV:          case ID_KEYMISC_SENDRECV:
1583              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_KEYSERVER, dlg,              dialog_box_param (glob_hinst, (LPCSTR)IDD_WINPT_KEYSERVER, dlg,
1584                                keyserver_dlg_proc, 0, _("Keyserver Access"),                                keyserver_dlg_proc, 0, _("Keyserver Access"),
1585                                IDS_WINPT_KEYSERVER);                                IDS_WINPT_KEYSERVER);
1586              refresh_keylist (kmi->lv);              refresh_keylist (kmi);
1587              return TRUE;              return TRUE;
1588                            
1589          case ID_KEYMISC_GPGPREFS:          case ID_KEYMISC_GPGPREFS:
# Line 1591  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1601  keymanager_dlg_proc (HWND dlg, UINT msg,
1601          case ID_KEYMISC_IMPORT:          case ID_KEYMISC_IMPORT:
1602              t = get_fileopen_dlg (dlg, _("Choose Name of the Key File"),              t = get_fileopen_dlg (dlg, _("Choose Name of the Key File"),
1603                                    NULL, NULL);                                    NULL, NULL);
1604              if (t)              if (!t)
1605                  km_file_import (dlg, t);                  break;
1606                if (!km_file_import (dlg, t))
1607                    refresh_keylist (kmi);
1608              return TRUE;              return TRUE;
1609    
1610          case ID_KEYMISC_IMPORT_HTTP:          case ID_KEYMISC_IMPORT_HTTP:
1611              url = (struct URL_ctx_s*)get_http_file_dlg (dlg);              url = (struct URL_ctx_s*)get_http_file_dlg (dlg);
1612              if (url->cancel == 0)              if (url->cancel == 0) {
1613                  km_http_import (dlg, url->url);                  km_http_import (dlg, url->url);
1614              delete url; url=NULL;                  refresh_keylist (kmi);
1615                }
1616                free_if_alloc (url);
1617              break;              break;
1618                            
1619          case ID_KEYMISC_EXPORT:          case ID_KEYMISC_EXPORT:
# Line 1683  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1697  keymanager_dlg_proc (HWND dlg, UINT msg,
1697                  BUG (NULL);                  BUG (NULL);
1698              /* XXX: pub/crd = secret key does not work */              /* XXX: pub/crd = secret key does not work */
1699              memset (&k, 0, sizeof (k));              memset (&k, 0, sizeof (k));
1700                strncpy (k.tmp_keyid, key->subkeys->keyid+8, 8);
1701                k.keyid = k.tmp_keyid;
1702              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);
1703              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);
             k.keyid = key->subkeys->keyid+8;  
1704              k.is_v3 = km_key_is_v3 (kmi->lv, kmi->lv_idx);              k.is_v3 = km_key_is_v3 (kmi->lv, kmi->lv_idx);
1705              k.flags = km_get_key_status (kmi->lv, kmi->lv_idx);              k.flags = km_get_key_status (kmi->lv, kmi->lv_idx);
1706              dialog_box_param (glob_hinst, (LPCTSTR)IDD_WINPT_KEYEDIT, dlg,              dialog_box_param (glob_hinst, (LPCTSTR)IDD_WINPT_KEYEDIT, dlg,
1707                                keyedit_main_dlg_proc, (LPARAM)&k,                                keyedit_main_dlg_proc, (LPARAM)&k,
1708                                _("Key Edit"), IDS_KEYCTX_EDIT);                                _("Key Edit"), IDS_KEYCTX_EDIT);
1709              if (k.update)              if (k.update)
1710                  update_key (kmi->lv,  kmi->lv_idx, k.keyid, 1);                  update_key (kmi->lv,  kmi->lv_idx, k.tmp_keyid, 1);
1711              break;              break;
1712                            
1713          case ID_KEYMISC_COPY:          case ID_KEYMISC_COPY:
# Line 1704  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1719  keymanager_dlg_proc (HWND dlg, UINT msg,
1719              break;              break;
1720    
1721          case ID_KEYMISC_PASTE:          case ID_KEYMISC_PASTE:
1722              km_clip_import (dlg);              if (!km_clip_import (dlg))
1723                    refresh_keylist (kmi);
1724              break;              break;
1725                            
1726          case ID_KEYCTX_SETPREFKS:          case ID_KEYCTX_SETPREFKS:
# Line 1764  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1780  keymanager_dlg_proc (HWND dlg, UINT msg,
1780              if (!key)              if (!key)
1781                  BUG (NULL);                  BUG (NULL);
1782              memset (&k, 0, sizeof (k));              memset (&k, 0, sizeof (k));
1783                strncpy (k.tmp_keyid, key->subkeys->keyid+8, 8);
1784                k.keyid = k.tmp_keyid;
1785              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);
1786              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);
             k.keyid = key->subkeys->keyid+8;  
1787              keyedit_add_subkey (&k, dlg, NULL);              keyedit_add_subkey (&k, dlg, NULL);
1788              if (k.update)              if (k.update)
1789                  update_key (kmi->lv, kmi->lv_idx, k.keyid, 1);                  update_key (kmi->lv, kmi->lv_idx, k.tmp_keyid, 1);
1790              break;              break;
1791    
1792          case ID_KEYCTX_ADDUID:          case ID_KEYCTX_ADDUID:
# Line 1777  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1794  keymanager_dlg_proc (HWND dlg, UINT msg,
1794              if (!key)              if (!key)
1795                  BUG (NULL);                  BUG (NULL);
1796              memset (&k, 0, sizeof (k));              memset (&k, 0, sizeof (k));
1797                strncpy (k.tmp_keyid, key->subkeys->keyid+8, 8);
1798                k.keyid = k.tmp_keyid;
1799              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);
1800              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);
             k.keyid = key->subkeys->keyid+8;  
1801              keyedit_add_userid (&k, dlg, NULL);              keyedit_add_userid (&k, dlg, NULL);
1802              if (k.update)              if (k.update)
1803                  update_key (kmi->lv, kmi->lv_idx, k.keyid, 1);                  update_key (kmi->lv, kmi->lv_idx, k.tmp_keyid, 1);
1804              break;              break;
1805    
1806          case ID_KEYCTX_ADDREV:          case ID_KEYCTX_ADDREV:
# Line 1790  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1808  keymanager_dlg_proc (HWND dlg, UINT msg,
1808              if (!key)              if (!key)
1809                  BUG (NULL);                  BUG (NULL);
1810              memset (&k, 0, sizeof (k));              memset (&k, 0, sizeof (k));
1811              k.keyid = key->subkeys->keyid+8;              strncpy (k.tmp_keyid, key->subkeys->keyid+8, 8);
1812                k.keyid = k.tmp_keyid;
1813              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);
1814              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);
1815              keyedit_add_revoker (&k, dlg);              keyedit_add_revoker (&k, dlg);
1816              if (k.update)              if (k.update)
1817                  update_key (kmi->lv, kmi->lv_idx, k.keyid, 1);                  update_key (kmi->lv, kmi->lv_idx, k.tmp_keyid, 1);
1818              break;              break;
1819    
1820          case ID_KEYCTX_ADDPHOTO:          case ID_KEYCTX_ADDPHOTO:
# Line 1803  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1822  keymanager_dlg_proc (HWND dlg, UINT msg,
1822              if (!key)              if (!key)
1823                  BUG (NULL);                  BUG (NULL);
1824              memset (&k, 0, sizeof (k));              memset (&k, 0, sizeof (k));
1825              k.keyid = key->subkeys->keyid+8;              strncpy (k.tmp_keyid, key->subkeys->keyid+8, 8);
1826                k.keyid = k.tmp_keyid;
1827              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);              k.is_protected = km_check_if_protected (kmi->lv, kmi->lv_idx);
1828              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);              k.key_pair = km_check_for_seckey (kmi->lv, kmi->lv_idx, NULL);
1829              keyedit_add_photo (&k, dlg);              keyedit_add_photo (&k, dlg);
1830              if (k.update)              if (k.update)
1831                  update_key (kmi->lv, kmi->lv_idx, k.keyid, 1);                  update_key (kmi->lv, kmi->lv_idx, k.tmp_keyid, 1);
1832              break;              break;
1833    
1834          case ID_KEYCTX_KS_NL:          case ID_KEYCTX_KS_NL:
# Line 1856  keymanager_dlg_proc (HWND dlg, UINT msg, Line 1876  keymanager_dlg_proc (HWND dlg, UINT msg,
1876              break;              break;
1877    
1878          case ID_KEYCTX_COPY:          case ID_KEYCTX_COPY:
1879              km_clip_export (dlg, kmi->lv);              send_cmd_id (dlg, ID_KEYMISC_COPY);
1880              break;              break;
1881    
1882          case ID_KEYCTX_PASTE:          case ID_KEYCTX_PASTE:
1883              km_clip_import (dlg);              send_cmd_id (dlg, ID_KEYMISC_PASTE);
1884              break;              break;
1885    
1886          case ID_KEYCTX_DISABLE:          case ID_KEYCTX_DISABLE:

Legend:
Removed from v.149  
changed lines
  Added in v.150

[email protected]
ViewVC Help
Powered by ViewVC 1.1.26