A whole bunch of changes to allow building for Windows.
[gnupg.git] / agent / preset-passphrase.c
index 013c941..7ff8425 100644 (file)
@@ -110,48 +110,43 @@ my_strusage (int level)
 }
 
 
+\f
 
-static void
-i18n_init (void)
+/* Include the implementation of map_spwq_error.  */
+MAP_SPWQ_ERROR_IMPL
+      
+/* Convert the string SRC into HEX encoding.  Caller needs to xfree
+   the returned string.  */
+static char *
+make_hexstring (const char *src)
 {
-#ifdef USE_SIMPLE_GETTEXT
-    set_gettext_file( PACKAGE_GT );
-#else
-#ifdef ENABLE_NLS
-    setlocale (LC_ALL, "");
-    bindtextdomain (PACKAGE_GT, LOCALEDIR);
-    textdomain (PACKAGE_GT);
-#endif
-#endif
-}
+  int len = 2 * strlen (src) + 1;
+  char *dst;
+  char *res;
 
-\f
-static gpg_error_t
-map_spwq_error (int err)
-{
-  switch (err)
+  res = dst = xtrymalloc (len);
+  if (!dst)
     {
-    case 0:
-      return 0;
-    case SPWQ_OUT_OF_CORE:
-      return gpg_error_from_errno (ENOMEM);
-    case SPWQ_IO_ERROR:
-      return gpg_error_from_errno (EIO);
-    case SPWQ_PROTOCOL_ERROR:
-      return gpg_error (GPG_ERR_PROTOCOL_VIOLATION);
-    case SPWQ_ERR_RESPONSE:
-      return gpg_error (GPG_ERR_INV_RESPONSE);
-    case SPWQ_NO_AGENT:
-      return gpg_error (GPG_ERR_NO_AGENT);
-    case SPWQ_SYS_ERROR:
-      return gpg_error_from_errno (errno);
-    case SPWQ_GENERAL_ERROR:
-    default:
-      return gpg_error (GPG_ERR_GENERAL);
+      log_error ("can not escape string: %s\n",
+                gpg_strerror (gpg_error_from_syserror ()));
+      return NULL;
     }
+
+#define _tohex(nr)     ((nr) < 10 ? ((nr) + '0') : (((nr) - 10) + 'A'))
+#define tohex1(p)  _tohex (*((unsigned char *) p) & 15)
+#define tohex2(p)  _tohex ((*((unsigned char *) p) >> 4) & 15)
+
+  while (*src)
+    {
+      *(dst++) = tohex2 (src);
+      *(dst++) = tohex1 (src);
+      src++;
+    }
+  *dst = '\0';
+  return res;
 }
 
-      
+
 static void
 preset_passphrase (const char *keygrip)
 {
@@ -159,6 +154,7 @@ preset_passphrase (const char *keygrip)
   char *line;
   /* FIXME: Use secure memory.  */
   char passphrase[500];
+  char *passphrase_esc;
 
   if (!opt_passphrase)
     {
@@ -166,14 +162,13 @@ preset_passphrase (const char *keygrip)
       if (rc < 0)
         {
           log_error ("reading passphrase failed: %s\n",
-                     gpg_strerror (gpg_error_from_errno (errno)));
+                     gpg_strerror (gpg_error_from_syserror ()));
           return;
         }
       passphrase[rc] = '\0';
       line = strchr (passphrase, '\n');
       if (line)
         {
-          line--;
           if (line > passphrase && line[-1] == '\r')
             line--;
           *line = '\0';
@@ -182,12 +177,23 @@ preset_passphrase (const char *keygrip)
       /* FIXME: How to handle empty passwords?  */
     }
 
+  passphrase_esc = make_hexstring (opt_passphrase
+                                  ? opt_passphrase : passphrase);
+  if (!passphrase_esc)
+    {
+      /* Error message printed by callee.  */
+      return;
+    }
+
   rc = asprintf (&line, "PRESET_PASSPHRASE %s -1 %s\n", keygrip,
-                 opt_passphrase? opt_passphrase : passphrase);
+                passphrase_esc);
+  wipememory (passphrase_esc, strlen (passphrase_esc));
+  xfree (passphrase_esc);
+
   if (rc < 0)
     {
       log_error ("caching passphrase failed: %s\n",
-                gpg_strerror (gpg_error_from_errno (errno)));
+                gpg_strerror (gpg_error_from_syserror ()));
       return;
     }
   if (!opt_passphrase)
@@ -215,7 +221,7 @@ forget_passphrase (const char *keygrip)
   if (rc < 0)
     {
       log_error ("clearing passphrase failed: %s\n",
-                gpg_strerror (gpg_error_from_errno (errno)));
+                gpg_strerror (gpg_error_from_syserror ()));
       return;
     }
   free (line);
@@ -232,18 +238,8 @@ main (int argc, char **argv)
   set_strusage (my_strusage);
   log_set_prefix ("gpg-preset-passphrase", 1); 
 
-  /* Try to auto set the character set.  */
-  set_native_charset (NULL); 
-
-#ifdef HAVE_W32_SYSTEM
-  /* Fixme: Need to initialize the Windows sockets: This should be
-     moved to another place and we should make sure that it won't get
-     doen twice, like when Pth is used too. */
-  {
-    WSADATA wsadat;
-    WSAStartup (0x202, &wsadat);
-  }
-#endif
+  /* Make sure that our subsystems are ready.  */
+  init_common_subsystems ();
 
   i18n_init ();
 
@@ -274,6 +270,13 @@ main (int argc, char **argv)
   else
     usage (1);
 
+  /* Tell simple-pwquery about the the standard socket name.  */
+  {
+    char *tmp = make_filename (opt_homedir, "S.gpg-agent", NULL);
+    simple_pw_set_socket (tmp);
+    xfree (tmp);
+  }
+
   if (cmd == oPreset)
     preset_passphrase (keygrip);
   else if (cmd == oForget)