Browse Source

2006-10-26 Marcus Brinkmann <marcus@g10code.de>

	* src/error-mapping.c (scute_gpg_err_to_ck): Map GPG_ERR_NO_AGENT
	to CKR_GENERAL_ERROR.
	* src/agent.h (struct agent_card_info_s): Remove member error.
	Prefix external functions with scute_ if not already done so, also
	for callers.
	* src/agent.c: Include <stdarg.h>.  Replace one-letter variable
	names by proper ones.  Replace assuan_error_t with gpg_error_t
	everywhere.
	(agent_connect, agent_simple_cmd, agent_configure): New functions.
	(scute_agent_initialize): Use these new functions.
	ing of common code.  Lots of cleanups.
	(scute_agent_finalize): Clear agent_ctx.  Add debug message.
Marcus Brinkmann 19 years ago
parent
commit
bb97372129
7 changed files with 228 additions and 170 deletions
  1. 15 0
      ChangeLog
  2. 1 0
      TODO
  3. 181 154
      src/agent.c
  4. 20 11
      src/agent.h
  5. 2 0
      src/debug.h
  6. 3 0
      src/error-mapping.c
  7. 6 5
      src/slots.c

+ 15 - 0
ChangeLog

@@ -1,3 +1,18 @@
+2006-10-26  Marcus Brinkmann  <marcus@g10code.de>
+
+	* src/error-mapping.c (scute_gpg_err_to_ck): Map GPG_ERR_NO_AGENT
+	to CKR_GENERAL_ERROR.
+	* src/agent.h (struct agent_card_info_s): Remove member error.
+	Prefix external functions with scute_ if not already done so, also
+	for callers.
+	* src/agent.c: Include <stdarg.h>.  Replace one-letter variable
+	names by proper ones.  Replace assuan_error_t with gpg_error_t
+	everywhere.
+	(agent_connect, agent_simple_cmd, agent_configure): New functions.
+	(scute_agent_initialize): Use these new functions.
+	ing of common code.  Lots of cleanups.
+	(scute_agent_finalize): Clear agent_ctx.  Add debug message.
+
 2006-10-13  Werner Koch  <wk@g10code.com>
 2006-10-13  Werner Koch  <wk@g10code.com>
 
 
 	* src/cert-gpgsm.c (MAX_LINE_LEN): Increased.
 	* src/cert-gpgsm.c (MAX_LINE_LEN): Increased.

+ 1 - 0
TODO

@@ -17,6 +17,7 @@
 
 
 * Missing features:
 * Missing features:
 ** Implement random number generation function C_GenerateRandom.
 ** Implement random number generation function C_GenerateRandom.
+** Add canonical gnupg logging module.
 
 
 * Standard ambiguities, or non-conformance in the applications:
 * Standard ambiguities, or non-conformance in the applications:
 ** If the token is removed, the current sessions are closed.  If then
 ** If the token is removed, the current sessions are closed.  If then

+ 181 - 154
src/agent.c

@@ -39,43 +39,34 @@
 #include <locale.h>
 #include <locale.h>
 #include <errno.h>
 #include <errno.h>
 #include <string.h>
 #include <string.h>
+#include <stdarg.h>
 
 
 #include <assuan.h>
 #include <assuan.h>
 #include <gpg-error.h>
 #include <gpg-error.h>
 
 
 #include "debug.h"
 #include "debug.h"
-#include "agent.h"
 #include "support.h"
 #include "support.h"
+#include "agent.h"
 
 
 
 
 /* The global agent context.  */
 /* The global agent context.  */
 static assuan_context_t agent_ctx = NULL;
 static assuan_context_t agent_ctx = NULL;
 
 
 
 
-/* Try to connect to the agent via socket or fork it off and work by
-   pipes.  Handle the server's initial greeting.  */
-gpg_error_t
-scute_agent_initialize (void)
+/* Establish a connection to a running GPG agent.  */
+static gpg_error_t
+agent_connect (assuan_context_t *ctx_r)
 {
 {
-  assuan_error_t err = 0;
+  gpg_error_t err = 0;
   char *infostr;
   char *infostr;
-  char *p;
-  assuan_context_t ctx;
-  char *dft_display = NULL;
-  char *dft_ttyname = NULL;
-  char *dft_ttytype = NULL;
-  char *old_lc = NULL;
-  char *dft_lc = NULL;
+  char *ptr;
   int pid;
   int pid;
-  int prot;
-
-  if (agent_ctx)
-    return 0;
+  int protocol_version;
 
 
   infostr = getenv ("GPG_AGENT_INFO");
   infostr = getenv ("GPG_AGENT_INFO");
   if (!infostr)
   if (!infostr)
     {
     {
-      DEBUG ("no GPG agent detected");
+      DEBUG ("missing GPG_AGENT_INFO environment variable");
       return gpg_error (GPG_ERR_NO_AGENT);
       return gpg_error (GPG_ERR_NO_AGENT);
     }
     }
 
 
@@ -83,146 +74,165 @@ scute_agent_initialize (void)
   if (!infostr)
   if (!infostr)
     return gpg_error_from_errno (errno);
     return gpg_error_from_errno (errno);
 
 
-  if (!(p = strchr (infostr, ':')) || p == infostr)
+  if (!(ptr = strchr (infostr, ':')) || ptr == infostr)
     {
     {
       DEBUG ("malformed GPG_AGENT_INFO environment variable");
       DEBUG ("malformed GPG_AGENT_INFO environment variable");
       free (infostr);
       free (infostr);
       return gpg_error (GPG_ERR_NO_AGENT);
       return gpg_error (GPG_ERR_NO_AGENT);
     }
     }
-  *p++ = 0;
-  pid = atoi (p);
-  while (*p && *p != ':')
-    p++;
-  prot = *p ? atoi (p + 1) : 0;
-  if (prot != 1)
+  *(ptr++) = 0;
+  pid = atoi (ptr);
+  while (*ptr && *ptr != ':')
+    ptr++;
+  protocol_version = *ptr ? atoi (ptr + 1) : 0;
+  if (protocol_version != 1)
     {
     {
-      DEBUG ("gpg-agent protocol version %d is not supported", prot);
+      DEBUG ("GPG agent protocol version '%d' not supported",
+	     protocol_version);
       free (infostr);
       free (infostr);
       return gpg_error (GPG_ERR_NO_AGENT);
       return gpg_error (GPG_ERR_NO_AGENT);
     }
     }
 
 
-  err = assuan_socket_connect (&ctx, infostr, pid);
+  err = assuan_socket_connect (ctx_r, infostr, pid);
   free (infostr);
   free (infostr);
   if (err)
   if (err)
     {
     {
-      DEBUG ("can't connect to GPG agent: %s", assuan_strerror (err));
+      DEBUG ("cannot connect to GPG agent: %s", gpg_strerror (err));
       return gpg_error (GPG_ERR_NO_AGENT);
       return gpg_error (GPG_ERR_NO_AGENT);
     }
     }
-  agent_ctx = ctx;
 
 
-  err = assuan_transact (agent_ctx, "RESET",
-			 NULL, NULL, NULL, NULL, NULL, NULL);
+  return 0;
+}
+
+
+/* Send a simple command to the agent.  */
+static gpg_error_t 
+agent_simple_cmd (assuan_context_t ctx, const char *fmt, ...)
+{
+  gpg_error_t err;
+  char *optstr;
+  va_list arg;
+  int res;
+
+  va_start (arg, fmt);
+  res = vasprintf (&optstr, fmt, arg);
+  va_end (arg);
+
+  if (res < 0)
+    return gpg_error_from_errno (errno);
+
+  err = assuan_transact (ctx, optstr, NULL, NULL, NULL, NULL, NULL, NULL);
+  if (err)
+    DEBUG ("gpg-agent command '%s' failed: %s", optstr, gpg_strerror (err));
+  free (optstr);
+      
+  return err;
+}
+  
+
+/* Configure the GPG agent at connection CTX.  */
+static gpg_error_t
+agent_configure (assuan_context_t ctx)
+{
+  gpg_error_t err = 0;
+  char *dft_display = NULL;
+  char *dft_ttyname = NULL;
+  char *dft_ttytype = NULL;
+#if defined(HAVE_SETLOCALE) && (defined(LC_CTYPE) || defined(LC_MESSAGES))
+  char *old_lc = NULL;
+  char *dft_lc = NULL;
+#endif
+
+  err = agent_simple_cmd (ctx, "RESET");
   if (err)
   if (err)
     return err;
     return err;
 
 
   /* Set up display, terminal and locale options.  */
   /* Set up display, terminal and locale options.  */
   dft_display = getenv ("DISPLAY");
   dft_display = getenv ("DISPLAY");
   if (dft_display)
   if (dft_display)
-    {
-      char *optstr;
-      if (asprintf (&optstr, "OPTION display=%s", dft_display) < 0)
-	err = gpg_error_from_errno (errno);
-      else
-	{
-	  err = assuan_transact (agent_ctx, optstr,
-				 NULL, NULL, NULL, NULL, NULL, NULL);
-	  free (optstr);
-	}
-    }
+    err = agent_simple_cmd (ctx, "OPTION display=%s", dft_display);
+  if (err)
+    return err;
+
   dft_ttyname = getenv ("GPG_TTY");
   dft_ttyname = getenv ("GPG_TTY");
   if ((!dft_ttyname || !*dft_ttyname) && ttyname (0))
   if ((!dft_ttyname || !*dft_ttyname) && ttyname (0))
     dft_ttyname = ttyname (0);
     dft_ttyname = ttyname (0);
-  if (!err)
-    {
-      if (dft_ttyname)
-	{
-	  char *optstr;
-	  if (asprintf (&optstr, "OPTION ttyname=%s", dft_ttyname) < 0)
-	    err = gpg_error_from_errno (errno);
-	  else
-	    {
-	      err = assuan_transact (agent_ctx, optstr,
-				     NULL, NULL, NULL, NULL, NULL, NULL);
-	      free (optstr);
-	    }
-	}
-    }
+  if (!dft_ttyname)
+    return 0;
+
+  err = agent_simple_cmd (ctx, "OPTION ttyname=%s", dft_ttyname);
+  if (err)
+    return err;
+
   dft_ttytype = getenv ("TERM");
   dft_ttytype = getenv ("TERM");
-  if (!err && dft_ttyname && dft_ttytype)
-    {
-      char *optstr;
-      if (asprintf (&optstr, "OPTION ttytype=%s", dft_ttytype) < 0)
-	err = gpg_error_from_errno (errno);
-      else
-	{
-	  err = assuan_transact (agent_ctx, optstr,
-				 NULL, NULL, NULL, NULL, NULL, NULL);
-	  free (optstr);
-	}
-    }
+  if (dft_ttytype)
+    err = agent_simple_cmd (ctx, "OPTION ttytype=%s", dft_ttytype);
+  if (err)
+    return err;
+
+#if defined(HAVE_SETLOCALE) && defined(LC_CTYPE)
   old_lc = setlocale (LC_CTYPE, NULL);
   old_lc = setlocale (LC_CTYPE, NULL);
-  if (!err && old_lc)
+  if (old_lc)
     {
     {
       old_lc = strdup (old_lc);
       old_lc = strdup (old_lc);
       if (!old_lc)
       if (!old_lc)
-        err = gpg_error_from_errno (errno);
+	return gpg_error_from_errno (errno);
     }
     }
   dft_lc = setlocale (LC_CTYPE, "");
   dft_lc = setlocale (LC_CTYPE, "");
-  if (!err && dft_ttyname && dft_lc)
-    {
-      char *optstr;
-      if (asprintf (&optstr, "OPTION lc-ctype=%s", dft_lc) < 0)
-	err = gpg_error_from_errno (errno);
-      else
-	{
-	  err = assuan_transact (agent_ctx, optstr,
-				 NULL, NULL, NULL, NULL, NULL, NULL);
-	  free (optstr);
-	}
-    }
-#if defined(HAVE_SETLOCALE) && defined(LC_CTYPE)
-  if (!err && old_lc)
+  if (dft_lc)
+    err = agent_simple_cmd ("OPTION lc-ctype=%s", dft_lc);
+  if (old_lc)
     {
     {
       setlocale (LC_CTYPE, old_lc);
       setlocale (LC_CTYPE, old_lc);
       free (old_lc);
       free (old_lc);
     }
     }
 #endif
 #endif
+  if (err)
+    return err;
 
 
+#if defined(HAVE_SETLOCALE) && defined(LC_MESSAGES)
   old_lc = setlocale (LC_MESSAGES, NULL);
   old_lc = setlocale (LC_MESSAGES, NULL);
-  if (!err && old_lc)
+  if (old_lc)
     {
     {
       old_lc = strdup (old_lc);
       old_lc = strdup (old_lc);
       if (!old_lc)
       if (!old_lc)
-        err = gpg_error_from_errno (errno);
-    }
-  dft_lc = setlocale (LC_MESSAGES, "");
-  if (!err && dft_ttyname && dft_lc)
-    {
-      char *optstr;
-      if (asprintf (&optstr, "OPTION lc-messages=%s", dft_lc) < 0)
 	err = gpg_error_from_errno (errno);
 	err = gpg_error_from_errno (errno);
-      else
-	{
-	  err = assuan_transact (agent_ctx, optstr,
-				 NULL, NULL, NULL, NULL, NULL, NULL);
-	  free (optstr);
-	}
     }
     }
-#if defined(HAVE_SETLOCALE) && defined(LC_MESSAGES)
-  if (!err && old_lc)
+  dft_lc = setlocale (LC_MESSAGES, "");
+  if (dft_lc)
+    err = agent_simple_cmd ("OPTION lc-messages=%s", dft_lc);
+  if (old_lc)
     {
     {
       setlocale (LC_MESSAGES, old_lc);
       setlocale (LC_MESSAGES, old_lc);
       free (old_lc);
       free (old_lc);
     }
     }
 #endif
 #endif
 
 
-  if (err)
+  return err;
+}
+
+
+/* Try to connect to the agent via socket.  Handle the server's
+   initial greeting.  */
+gpg_error_t
+scute_agent_initialize (void)
+{
+  gpg_error_t err = 0;
+
+  if (agent_ctx)
     {
     {
-      /* Setting some options failed.  Tear down the agent
-	 connection.  */
-      assuan_disconnect (agent_ctx);
+      DEBUG ("GPG Agent connection already established");
+      return 0;
     }
     }
 
 
+  err = agent_connect (&agent_ctx);
+  if (err)
+    return err;
+
+  err = agent_configure (agent_ctx);
+  if (err)
+    scute_agent_finalize ();
+
   return err;
   return err;
 }
 }
 
 
@@ -232,53 +242,61 @@ scute_agent_initialize (void)
    silently be replaced by a 0xFF.  Function returns NULL to indicate
    silently be replaced by a 0xFF.  Function returns NULL to indicate
    an out of memory status.  */
    an out of memory status.  */
 static char *
 static char *
-unescape_status_string (const unsigned char *s)
+unescape_status_string (const unsigned char *src)
 {
 {
-  char *buffer, *d;
+  char *buffer;
+  char *dst;
 
 
-  buffer = d = malloc (strlen (s) + 1);
+  buffer = malloc (strlen (src) + 1);
   if (!buffer)
   if (!buffer)
     return NULL;
     return NULL;
-  while (*s)
+
+  dst = buffer;
+  while (*src)
     {
     {
-      if (*s == '%' && s[1] && s[2])
+      if (*src == '%' && src[1] && src[2])
         { 
         { 
-          s++;
-          *d = xtoi_2 (s);
-          if (!*d)
-            *d = '\xff';
-          d++;
-          s += 2;
+          src++;
+          *dst = xtoi_2 (src);
+          if (*dst == '\0')
+            *dst = '\xff';
+          dst++;
+          src += 2;
         }
         }
-      else if (*s == '+')
+      else if (*src == '+')
         {
         {
-          *d++ = ' ';
-          s++;
+          *(dst++) = ' ';
+          src++;
         }
         }
       else
       else
-        *d++ = *s++;
+        *(dst++) = *(src++);
     }
     }
-  *d = 0; 
+  *dst = 0; 
+
   return buffer;
   return buffer;
 }
 }
 
 
 
 
 /* Take a 20 byte hexencoded string and put it into the the provided
 /* Take a 20 byte hexencoded string and put it into the the provided
-   20 byte buffer FPR in binary format.  */
+   20 byte buffer FPR in binary format.  Returns true if successful,
+   and false otherwise.  */
 static int
 static int
 unhexify_fpr (const char *hexstr, unsigned char *fpr)
 unhexify_fpr (const char *hexstr, unsigned char *fpr)
 {
 {
-  const char *s;
-  int n;
+  const char *src;
+  int cnt;
 
 
-  for (s = hexstr, n = 0; hexdigitp (s); s++, n++)
+  /* Check for invalid or wrong length.  */
+  for (src = hexstr, cnt = 0; hexdigitp (src); src++, cnt++)
     ;
     ;
-  if ((*s && !spacep (s)) || (n != 40))
-    return 0;	/* No fingerprint (invalid or wrong length).  */
-  n /= 2;
-  for (s = hexstr, n = 0; *s && !spacep (s); s += 2, n++)
-    fpr[n] = xtoi_2 (s);
-  return 1; /* Okay.  */
+  if ((*src && !spacep (src)) || (cnt != 40))
+    return 0;
+
+  cnt /= 2;
+  for (src = hexstr, cnt = 0; *src && !spacep (src); src += 2, cnt++)
+    fpr[cnt] = xtoi_2 (src);
+
+  return 1;
 }
 }
 
 
 
 
@@ -288,24 +306,26 @@ unhexify_fpr (const char *hexstr, unsigned char *fpr)
 static char *
 static char *
 store_serialno (const char *line)
 store_serialno (const char *line)
 {
 {
-  const char *s;
-  char *p;
+  const char *src;
+  char *ptr;
 
 
-  for (s = line; hexdigitp (s); s++)
+  for (src = line; hexdigitp (src); src++)
     ;
     ;
-  p = malloc (s + 1 - line);
-  if (p)
+  ptr = malloc (src + 1 - line);
+
+  if (ptr)
     {
     {
-      memcpy (p, line, s-line);
-      p[s-line] = 0;
+      memcpy (ptr, line, src - line);
+      ptr[src - line] = 0;
     }
     }
-  return p;
+
+  return ptr;
 }
 }
 
 
 
 
 /* Release the card info structure INFO.  */
 /* Release the card info structure INFO.  */
 void
 void
-agent_release_card_info (struct agent_card_info_s *info)
+scute_agent_release_card_info (struct agent_card_info_s *info)
 {
 {
   if (!info)
   if (!info)
     return;
     return;
@@ -321,7 +341,7 @@ agent_release_card_info (struct agent_card_info_s *info)
 
 
 
 
 /* FIXME: We are not returning out of memory errors.  */
 /* FIXME: We are not returning out of memory errors.  */
-static assuan_error_t
+static gpg_error_t
 learn_status_cb (void *opaque, const char *line)
 learn_status_cb (void *opaque, const char *line)
 {
 {
   struct agent_card_info_s *parm = opaque;
   struct agent_card_info_s *parm = opaque;
@@ -474,9 +494,9 @@ learn_status_cb (void *opaque, const char *line)
 
 
 /* Call the agent to learn about a smartcard.  */
 /* Call the agent to learn about a smartcard.  */
 gpg_error_t
 gpg_error_t
-agent_learn (struct agent_card_info_s *info)
+scute_agent_learn (struct agent_card_info_s *info)
 {
 {
-  assuan_error_t err;
+  gpg_error_t err;
 
 
   memset (info, 0, sizeof (*info));
   memset (info, 0, sizeof (*info));
   err = assuan_transact (agent_ctx, "LEARN --send",
   err = assuan_transact (agent_ctx, "LEARN --send",
@@ -486,7 +506,7 @@ agent_learn (struct agent_card_info_s *info)
 }
 }
 
 
 
 
-static assuan_error_t
+static gpg_error_t
 read_status_cb (void *opaque, const void *buffer, size_t length)
 read_status_cb (void *opaque, const void *buffer, size_t length)
 {
 {
   char *flag = opaque;
   char *flag = opaque;
@@ -500,11 +520,13 @@ read_status_cb (void *opaque, const void *buffer, size_t length)
 }
 }
 
 
 
 
-/* Call the agent to learn about a smartcard.  */
+/* Check the agent status.  This returns 0 if a token is present,
+   GPG_ERR_CARD_REMOVED if no token is present, and an error code
+   otherwise.  */
 gpg_error_t
 gpg_error_t
-agent_check_status (void)
+scute_agent_check_status (void)
 {
 {
-  assuan_error_t err;
+  gpg_error_t err;
   char flag = '-';
   char flag = '-';
 
 
   err = assuan_transact (agent_ctx, "SCD GETINFO status",
   err = assuan_transact (agent_ctx, "SCD GETINFO status",
@@ -528,11 +550,10 @@ struct signature
   int len;
   int len;
 };
 };
 
 
-static assuan_error_t
+static gpg_error_t
 pksign_cb (void *opaque, const void *buffer, size_t length)
 pksign_cb (void *opaque, const void *buffer, size_t length)
 {
 {
   struct signature *sig = opaque;
   struct signature *sig = opaque;
-  int i;
 
 
   if (sig->len + length > MAX_SIGNATURE_LEN)
   if (sig->len + length > MAX_SIGNATURE_LEN)
     return gpg_error (GPG_ERR_BAD_DATA);
     return gpg_error (GPG_ERR_BAD_DATA);
@@ -552,11 +573,11 @@ pksign_cb (void *opaque, const void *buffer, size_t length)
 
 
 /* Call the agent to learn about a smartcard.  */
 /* Call the agent to learn about a smartcard.  */
 gpg_error_t
 gpg_error_t
-agent_sign (char *grip, unsigned char *data, int len,
-	    unsigned char *sig_result, unsigned int *sig_len)
+scute_agent_sign (char *grip, unsigned char *data, int len,
+		  unsigned char *sig_result, unsigned int *sig_len)
 {
 {
   char cmd[150];
   char cmd[150];
-  assuan_error_t err;
+  gpg_error_t err;
 #define MAX_DATA_LEN 36
 #define MAX_DATA_LEN 36
   unsigned char pretty_data[2 * MAX_DATA_LEN + 1];
   unsigned char pretty_data[2 * MAX_DATA_LEN + 1];
   int i;
   int i;
@@ -617,6 +638,12 @@ agent_sign (char *grip, unsigned char *data, int len,
 void
 void
 scute_agent_finalize (void)
 scute_agent_finalize (void)
 {
 {
-  if (agent_ctx)
-    assuan_disconnect (agent_ctx);
+  if (!agent_ctx)
+    {
+      DEBUG ("no GPG Agent connection established");
+      return;
+    }
+
+  assuan_disconnect (agent_ctx);
+  agent_ctx = NULL;
 }
 }

+ 20 - 11
src/agent.h

@@ -1,4 +1,4 @@
-/* agent.c - Talking to gpg-agent.
+/* agent.h - Interface for talking to gpg-agent.
    Copyright (C) 2006 g10 Code GmbH
    Copyright (C) 2006 g10 Code GmbH
 
 
    This file is part of Scute[1].
    This file is part of Scute[1].
@@ -39,7 +39,6 @@
 /* The information structure for a smart card.  */
 /* The information structure for a smart card.  */
 struct agent_card_info_s 
 struct agent_card_info_s 
 {
 {
-  int error;		/* Private.  */
   char *serialno;	/* Malloced hex string.  */
   char *serialno;	/* Malloced hex string.  */
   char *disp_name;	/* Malloced.  */
   char *disp_name;	/* Malloced.  */
   char *disp_lang;	/* Malloced.  */
   char *disp_lang;	/* Malloced.  */
@@ -77,22 +76,32 @@ struct agent_card_info_s
 };
 };
 
 
 
 
-/* Try to connect to the agent via socket or fork it off and work by
-   pipes.  Handle the server's initial greeting.  */
+/* Try to connect to the agent via socket.  Handle the server's
+   initial greeting.  */
 gpg_error_t scute_agent_initialize (void);
 gpg_error_t scute_agent_initialize (void);
 
 
+/* Tear down the agent connection and release all associated
+   resources.  */
 void scute_agent_finalize (void);
 void scute_agent_finalize (void);
 
 
-/* Release the card info structure INFO.  */
-void agent_release_card_info (struct agent_card_info_s *info);
+
+/* Check the agent status.  This returns 0 if a token is present,
+   GPG_ERR_CARD_REMOVED if no token is present, and an error code
+   otherwise.  */
+gpg_error_t scute_agent_check_status (void);
 
 
-/* Call the agent to learn about a smartcard.  */
-gpg_error_t agent_learn (struct agent_card_info_s *info);
 
 
 /* Call the agent to learn about a smartcard.  */
 /* Call the agent to learn about a smartcard.  */
-gpg_error_t agent_check_status (void);
+gpg_error_t scute_agent_learn (struct agent_card_info_s *info);
+
+/* Release the card info structure INFO.  */
+void scute_agent_release_card_info (struct agent_card_info_s *info);
+
 
 
-gpg_error_t agent_sign (char *grip, unsigned char *data, int len,
-			unsigned char *sig_result, unsigned int *sig_len);
+/* Sign the data DATA of length LEN with the key GRIP and return the
+   signature in SIG_RESULT and SIG_LEN.  */
+gpg_error_t scute_agent_sign (char *grip, unsigned char *data, int len,
+			      unsigned char *sig_result,
+			      unsigned int *sig_len);
 
 
 #endif	/* AGENT_H */
 #endif	/* AGENT_H */

+ 2 - 0
src/debug.h

@@ -37,6 +37,8 @@
 
 
 #define DEBUG_PREFIX "scute: "
 #define DEBUG_PREFIX "scute: "
 
 
+/* FIXME: Eventually, we should control output with an environment
+   variable.  */
 #define DEBUG(format, ...) \
 #define DEBUG(format, ...) \
   fprintf (stderr, DEBUG_PREFIX "%s: " format "\n", __func__, ##__VA_ARGS__)
   fprintf (stderr, DEBUG_PREFIX "%s: " format "\n", __func__, ##__VA_ARGS__)
 
 

+ 3 - 0
src/error-mapping.c

@@ -72,6 +72,9 @@ scute_gpg_err_to_ck (gpg_error_t err)
     case GPG_ERR_NO_ERROR:
     case GPG_ERR_NO_ERROR:
       return CKR_OK;
       return CKR_OK;
 
 
+    case GPG_ERR_NO_AGENT:
+      return CKR_GENERAL_ERROR;
+
     case GPG_ERR_ENOMEM:
     case GPG_ERR_ENOMEM:
       return CKR_HOST_MEMORY;
       return CKR_HOST_MEMORY;
 
 

+ 6 - 5
src/slots.c

@@ -251,7 +251,7 @@ slots_update_slot (slot_iterator_t id)
 
 
   if (slot->token_present)
   if (slot->token_present)
     {
     {
-      err = agent_check_status ();
+      err = scute_agent_check_status ();
       if (gpg_err_code (err) == GPG_ERR_CARD_REMOVED)
       if (gpg_err_code (err) == GPG_ERR_CARD_REMOVED)
 	{
 	{
 	  /* FIXME: Reset the whole thing.  */
 	  /* FIXME: Reset the whole thing.  */
@@ -268,7 +268,7 @@ slots_update_slot (slot_iterator_t id)
 	      hurd_table_remove (&slot->objects, oidx);
 	      hurd_table_remove (&slot->objects, oidx);
 	    }
 	    }
 	  
 	  
-	  agent_release_card_info (&slot->info);
+	  scute_agent_release_card_info (&slot->info);
 	  slot->token_present = false;
 	  slot->token_present = false;
 	}
 	}
       else if (err)
       else if (err)
@@ -279,7 +279,7 @@ slots_update_slot (slot_iterator_t id)
 
 
   /* At this point, the card was or is removed, and we need to reopen
   /* At this point, the card was or is removed, and we need to reopen
      the session, if possible.  */
      the session, if possible.  */
-  err = agent_learn (&slot->info);
+  err = scute_agent_learn (&slot->info);
 
 
   /* First check if this is really an OpenPGP card.  FIXME: Should
   /* First check if this is really an OpenPGP card.  FIXME: Should
      probably report the error in a better way.  */
      probably report the error in a better way.  */
@@ -1069,7 +1069,7 @@ session_sign (slot_iterator_t id, session_iterator_t sid,
   /* FIXME: Who cares if they called sign init correctly.  */
   /* FIXME: Who cares if they called sign init correctly.  */
   if (pSignature == NULL_PTR)
   if (pSignature == NULL_PTR)
     {
     {
-      err = agent_sign (NULL, NULL, 0, NULL, &sig_len);
+      err = scute_agent_sign (NULL, NULL, 0, NULL, &sig_len);
       if (err)
       if (err)
 	return scute_gpg_err_to_ck (err);
 	return scute_gpg_err_to_ck (err);
       *pulSignatureLen = sig_len;
       *pulSignatureLen = sig_len;
@@ -1077,7 +1077,8 @@ session_sign (slot_iterator_t id, session_iterator_t sid,
     }
     }
 
 
   sig_len = *pulSignatureLen;
   sig_len = *pulSignatureLen;
-  err = agent_sign (slot->info.grip3, pData, ulDataLen, pSignature, &sig_len);
+  err = scute_agent_sign (slot->info.grip3, pData, ulDataLen,
+			  pSignature, &sig_len);
   /* FIXME: Oh well.  */
   /* FIXME: Oh well.  */
   if (gpg_err_code (err) == GPG_ERR_INV_ARG)
   if (gpg_err_code (err) == GPG_ERR_INV_ARG)
     return CKR_BUFFER_TOO_SMALL;
     return CKR_BUFFER_TOO_SMALL;