mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-03 12:11:33 +01:00
Mainly changes to adjust for the changed KSBA API.
This commit is contained in:
parent
f794da4ad4
commit
dba40e5e45
@ -329,7 +329,7 @@ cmd_pkdecrypt (ASSUAN_CONTEXT ctx, char *line)
|
|||||||
{
|
{
|
||||||
int rc;
|
int rc;
|
||||||
CTRL ctrl = assuan_get_pointer (ctx);
|
CTRL ctrl = assuan_get_pointer (ctx);
|
||||||
char *value;
|
unsigned char *value;
|
||||||
size_t valuelen;
|
size_t valuelen;
|
||||||
|
|
||||||
/* First inquire the data to decrypt */
|
/* First inquire the data to decrypt */
|
||||||
@ -365,7 +365,7 @@ cmd_genkey (ASSUAN_CONTEXT ctx, char *line)
|
|||||||
{
|
{
|
||||||
CTRL ctrl = assuan_get_pointer (ctx);
|
CTRL ctrl = assuan_get_pointer (ctx);
|
||||||
int rc;
|
int rc;
|
||||||
char *value;
|
unsigned char *value;
|
||||||
size_t valuelen;
|
size_t valuelen;
|
||||||
|
|
||||||
/* First inquire the parameters */
|
/* First inquire the parameters */
|
||||||
|
@ -137,7 +137,7 @@ agent_genkey (CTRL ctrl, const char *keyparam, size_t keyparamlen,
|
|||||||
{
|
{
|
||||||
log_error ("key generation failed: %s\n", gpg_strerror (rc));
|
log_error ("key generation failed: %s\n", gpg_strerror (rc));
|
||||||
xfree (pi);
|
xfree (pi);
|
||||||
return map_gcry_err (rc);
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* break out the parts */
|
/* break out the parts */
|
||||||
|
@ -105,7 +105,6 @@ agent_pkdecrypt (CTRL ctrl, const char *ciphertext, size_t ciphertextlen,
|
|||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("decryption failed: %s\n", gpg_strerror (rc));
|
log_error ("decryption failed: %s\n", gpg_strerror (rc));
|
||||||
rc = map_gcry_err (rc);
|
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -39,7 +39,9 @@ do_encode_md (const byte * md, size_t mdlen, int algo, gcry_sexp_t * r_hash)
|
|||||||
char * p, tmp[16];
|
char * p, tmp[16];
|
||||||
int i, rc;
|
int i, rc;
|
||||||
|
|
||||||
#warning I do do like that stuff - libgcrypt provides easier interfaces. -wk
|
#ifdef __GNUC__
|
||||||
|
#warning I do not like that stuff - libgcrypt provides easier interfaces. -wk
|
||||||
|
#endif
|
||||||
/* FIXME: Either use the build function or create canonical encoded
|
/* FIXME: Either use the build function or create canonical encoded
|
||||||
S-expressions. */
|
S-expressions. */
|
||||||
|
|
||||||
@ -128,7 +130,6 @@ agent_pksign (CTRL ctrl, FILE *outfp, int ignore_cache)
|
|||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("signing failed: %s\n", gpg_strerror (rc));
|
log_error ("signing failed: %s\n", gpg_strerror (rc));
|
||||||
rc = map_gcry_err (rc);
|
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
2003-11-12 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
|
* maperror.c (map_ksba_err, map_gcry_err, map_kbx_err): Removed.
|
||||||
|
|
||||||
2003-10-31 Werner Koch <wk@gnupg.org>
|
2003-10-31 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
* util.h (gnupg_isotime_t): New.
|
* util.h (gnupg_isotime_t): New.
|
||||||
|
@ -32,49 +32,6 @@
|
|||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "errors.h"
|
#include "errors.h"
|
||||||
|
|
||||||
/* Note: we might want to wrap this in a macro to get our hands on
|
|
||||||
the line and file where the error occured */
|
|
||||||
int
|
|
||||||
map_ksba_err (int err)
|
|
||||||
{
|
|
||||||
switch (err)
|
|
||||||
{
|
|
||||||
case 0:
|
|
||||||
break;
|
|
||||||
|
|
||||||
case -1: err = GPG_ERR_EOF; break;
|
|
||||||
case KSBA_Out_Of_Core: err = GPG_ERR_ENOMEM; break;
|
|
||||||
case KSBA_Invalid_Value: err = GPG_ERR_INV_VALUE; break;
|
|
||||||
case KSBA_Not_Implemented: err = GPG_ERR_NOT_IMPLEMENTED; break;
|
|
||||||
case KSBA_Conflict: err = GPG_ERR_CONFLICT; break;
|
|
||||||
case KSBA_Read_Error: err = GPG_ERR_EIO; break;
|
|
||||||
case KSBA_Write_Error: err = GPG_ERR_EIO; break;
|
|
||||||
case KSBA_No_Data: err = GPG_ERR_NO_DATA; break;
|
|
||||||
case KSBA_Bug: err = GPG_ERR_BUG; break;
|
|
||||||
case KSBA_Unsupported_Algorithm: err = GPG_ERR_UNSUPPORTED_ALGORITHM; break;
|
|
||||||
case KSBA_Invalid_Index: err = GPG_ERR_INV_INDEX; break;
|
|
||||||
case KSBA_Invalid_Sexp: err = GPG_ERR_INV_SEXP; break;
|
|
||||||
case KSBA_Unknown_Sexp: err = GPG_ERR_UNKNOWN_SEXP; break;
|
|
||||||
|
|
||||||
default:
|
|
||||||
err = GPG_ERR_GENERAL;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
return gpg_err_make (GPG_ERR_SOURCE_GPGSM, err);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
int
|
|
||||||
map_gcry_err (int err)
|
|
||||||
{
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
int
|
|
||||||
map_kbx_err (int err)
|
|
||||||
{
|
|
||||||
return err;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Map Assuan error code ERR to an GPG_ERR_ code. We need to
|
/* Map Assuan error code ERR to an GPG_ERR_ code. We need to
|
||||||
distinguish between genuine (and legacy) Assuan error codes and
|
distinguish between genuine (and legacy) Assuan error codes and
|
||||||
|
@ -58,8 +58,6 @@ typedef char gnupg_isotime_t[16];
|
|||||||
|
|
||||||
|
|
||||||
/*-- maperror.c --*/
|
/*-- maperror.c --*/
|
||||||
int map_ksba_err (int err);
|
|
||||||
int map_gcry_err (int err);
|
|
||||||
int map_kbx_err (int err);
|
int map_kbx_err (int err);
|
||||||
gpg_error_t map_assuan_err (int err);
|
gpg_error_t map_assuan_err (int err);
|
||||||
int map_to_assuan_status (int rc);
|
int map_to_assuan_status (int rc);
|
||||||
|
@ -246,7 +246,9 @@ openpgp_pk_test_algo( int algo, unsigned int usage_flags )
|
|||||||
|
|
||||||
if (algo == GCRY_PK_ELG_E)
|
if (algo == GCRY_PK_ELG_E)
|
||||||
algo = GCRY_PK_ELG;
|
algo = GCRY_PK_ELG;
|
||||||
|
#ifdef __GNUC__
|
||||||
#warning need to handle the usage here?
|
#warning need to handle the usage here?
|
||||||
|
#endif
|
||||||
if (algo < 0 || algo > 110)
|
if (algo < 0 || algo > 110)
|
||||||
return GPG_ERR_PUBKEY_ALGO;
|
return GPG_ERR_PUBKEY_ALGO;
|
||||||
return gcry_pk_algo_info (algo, GCRYCTL_TEST_ALGO, NULL, &value);
|
return gcry_pk_algo_info (algo, GCRYCTL_TEST_ALGO, NULL, &value);
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
2003-11-06 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
|
* strlist.h (strlist_t): New. STRLIST is now deprecated.
|
||||||
|
|
||||||
2003-06-18 Werner Koch <wk@gnupg.org>
|
2003-06-18 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
* strlist.c (strlist_pop): New.
|
* strlist.c (strlist_pop): New.
|
||||||
|
@ -26,17 +26,22 @@ struct string_list {
|
|||||||
unsigned int flags;
|
unsigned int flags;
|
||||||
char d[1];
|
char d[1];
|
||||||
};
|
};
|
||||||
typedef struct string_list *STRLIST;
|
typedef struct string_list *STRLIST; /* Deprecated. */
|
||||||
|
typedef struct string_list *strlist_t;
|
||||||
|
|
||||||
|
void free_strlist (strlist_t sl);
|
||||||
|
strlist_t add_to_strlist (strlist_t *list, const char *string);
|
||||||
|
|
||||||
void free_strlist( STRLIST sl );
|
/*strlist_t add_to_strlist2( strlist_t *list,
|
||||||
STRLIST add_to_strlist( STRLIST *list, const char *string );
|
const char *string, int is_utf8);*/
|
||||||
/*STRLIST add_to_strlist2( STRLIST *list, const char *string, int is_utf8 );*/
|
|
||||||
STRLIST append_to_strlist( STRLIST *list, const char *string );
|
strlist_t append_to_strlist (strlist_t *list, const char *string);
|
||||||
/*STRLIST append_to_strlist2( STRLIST *list, const char *string, int is_utf8 );*/
|
|
||||||
STRLIST strlist_prev( STRLIST head, STRLIST node );
|
/*strlist_t append_to_strlist2( strlist_t *list, const char *string,
|
||||||
STRLIST strlist_last( STRLIST node );
|
int is_utf8);*/
|
||||||
char * strlist_pop (STRLIST *list);
|
strlist_t strlist_prev (strlist_t head, strlist_t node);
|
||||||
|
strlist_t strlist_last (strlist_t node);
|
||||||
|
char * strlist_pop (strlist_t *list);
|
||||||
|
|
||||||
#define FREE_STRLIST(a) do { free_strlist((a)); (a) = NULL ; } while(0)
|
#define FREE_STRLIST(a) do { free_strlist((a)); (a) = NULL ; } while(0)
|
||||||
|
|
||||||
|
@ -1,3 +1,9 @@
|
|||||||
|
2003-11-12 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
|
Adjusted for API changes in Libksba.
|
||||||
|
|
||||||
|
* keybox-blob.c: Include time.h
|
||||||
|
|
||||||
2003-06-03 Werner Koch <wk@gnupg.org>
|
2003-06-03 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
Changed all error codes in all files to the new libgpg-error scheme.
|
Changed all error codes in all files to the new libgpg-error scheme.
|
||||||
|
@ -110,6 +110,7 @@ X.509 specific are noted like [X.509: xxx]
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
#include <time.h>
|
||||||
|
|
||||||
#include "keybox-defs.h"
|
#include "keybox-defs.h"
|
||||||
#include <gcrypt.h>
|
#include <gcrypt.h>
|
||||||
|
@ -21,14 +21,15 @@
|
|||||||
#ifndef KEYBOX_DEFS_H
|
#ifndef KEYBOX_DEFS_H
|
||||||
#define KEYBOX_DEFS_H 1
|
#define KEYBOX_DEFS_H 1
|
||||||
|
|
||||||
#include <sys/types.h> /* off_t */
|
|
||||||
#include "keybox.h"
|
|
||||||
|
|
||||||
#ifdef GPG_ERR_SOURCE_DEFAULT
|
#ifdef GPG_ERR_SOURCE_DEFAULT
|
||||||
#error GPG_ERR_SOURCE_DEFAULT already defined
|
#error GPG_ERR_SOURCE_DEFAULT already defined
|
||||||
#endif
|
#endif
|
||||||
#define GPG_ERR_SOURCE_DEFAULT GPG_ERR_SOURCE_KEYBOX
|
#define GPG_ERR_SOURCE_DEFAULT GPG_ERR_SOURCE_KEYBOX
|
||||||
|
|
||||||
#include <gpg-error.h>
|
#include <gpg-error.h>
|
||||||
|
#include <sys/types.h> /* off_t */
|
||||||
|
#include "keybox.h"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef HAVE_BYTE_TYPEDEF
|
#ifndef HAVE_BYTE_TYPEDEF
|
||||||
|
@ -778,9 +778,9 @@ keybox_get_cert (KEYBOX_HANDLE hd, KsbaCert *r_cert)
|
|||||||
if (cert_off+cert_len > length)
|
if (cert_off+cert_len > length)
|
||||||
return gpg_error (GPG_ERR_TOO_SHORT);
|
return gpg_error (GPG_ERR_TOO_SHORT);
|
||||||
|
|
||||||
reader = ksba_reader_new ();
|
rc = ksba_reader_new (&reader);
|
||||||
if (!reader)
|
if (rc)
|
||||||
return gpg_error (GPG_ERR_ENOMEM);
|
return rc;
|
||||||
rc = ksba_reader_set_mem (reader, buffer+cert_off, cert_len);
|
rc = ksba_reader_set_mem (reader, buffer+cert_off, cert_len);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
@ -789,11 +789,11 @@ keybox_get_cert (KEYBOX_HANDLE hd, KsbaCert *r_cert)
|
|||||||
return gpg_error (GPG_ERR_GENERAL);
|
return gpg_error (GPG_ERR_GENERAL);
|
||||||
}
|
}
|
||||||
|
|
||||||
cert = ksba_cert_new ();
|
rc = ksba_cert_new (&cert);
|
||||||
if (!cert)
|
if (rc)
|
||||||
{
|
{
|
||||||
ksba_reader_release (reader);
|
ksba_reader_release (reader);
|
||||||
return gpg_error (GPG_ERR_ENOMEM);
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
rc = ksba_cert_read_der (cert, reader);
|
rc = ksba_cert_read_der (cert, reader);
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
2003-11-12 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
|
Adjusted for API changes in Libksba.
|
||||||
|
|
||||||
2003-10-30 Werner Koch <wk@gnupg.org>
|
2003-10-30 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
* apdu.c (close_ct_reader, close_pcsc_reader): Implemented.
|
* apdu.c (close_ct_reader, close_pcsc_reader): Implemented.
|
||||||
|
@ -79,9 +79,9 @@
|
|||||||
|
|
||||||
#ifdef HAVE_OPENSC
|
#ifdef HAVE_OPENSC
|
||||||
#include <opensc/pkcs15.h>
|
#include <opensc/pkcs15.h>
|
||||||
|
#include "scdaemon.h"
|
||||||
#include <ksba.h>
|
#include <ksba.h>
|
||||||
|
|
||||||
#include "scdaemon.h"
|
|
||||||
#include "card-common.h"
|
#include "card-common.h"
|
||||||
|
|
||||||
static int dinsig_read_cert (CARD card, const char *certidstr,
|
static int dinsig_read_cert (CARD card, const char *certidstr,
|
||||||
@ -113,12 +113,11 @@ dinsig_enum_keypairs (CARD card, int idx,
|
|||||||
if (rc)
|
if (rc)
|
||||||
return rc;
|
return rc;
|
||||||
|
|
||||||
cert = ksba_cert_new ();
|
rc = ksba_cert_new (&cert);
|
||||||
if (!cert)
|
if (rc)
|
||||||
{
|
{
|
||||||
gpg_error_t tmperr = out_of_core ();
|
|
||||||
xfree (buf);
|
xfree (buf);
|
||||||
return tmperr;
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
krc = ksba_cert_init_from_mem (cert, buf, buflen);
|
krc = ksba_cert_init_from_mem (cert, buf, buflen);
|
||||||
@ -126,9 +125,9 @@ dinsig_enum_keypairs (CARD card, int idx,
|
|||||||
if (krc)
|
if (krc)
|
||||||
{
|
{
|
||||||
log_error ("failed to parse the certificate at idx %d: %s\n",
|
log_error ("failed to parse the certificate at idx %d: %s\n",
|
||||||
idx, ksba_strerror (krc));
|
idx, gpg_strerror (krc));
|
||||||
ksba_cert_release (cert);
|
ksba_cert_release (cert);
|
||||||
return gpg_error (GPG_ERR_CARD);
|
return krc;
|
||||||
}
|
}
|
||||||
if (card_help_get_keygrip (cert, keygrip))
|
if (card_help_get_keygrip (cert, keygrip))
|
||||||
{
|
{
|
||||||
|
@ -27,9 +27,9 @@
|
|||||||
|
|
||||||
#ifdef HAVE_OPENSC
|
#ifdef HAVE_OPENSC
|
||||||
#include <opensc/pkcs15.h>
|
#include <opensc/pkcs15.h>
|
||||||
#include <ksba.h>
|
|
||||||
|
|
||||||
#include "scdaemon.h"
|
#include "scdaemon.h"
|
||||||
|
#include <ksba.h>
|
||||||
#include "card-common.h"
|
#include "card-common.h"
|
||||||
|
|
||||||
|
|
||||||
@ -148,21 +148,20 @@ p15_enum_keypairs (CARD card, int idx,
|
|||||||
return gpg_error (GPG_ERR_CARD);
|
return gpg_error (GPG_ERR_CARD);
|
||||||
}
|
}
|
||||||
|
|
||||||
cert = ksba_cert_new ();
|
rc = ksba_cert_new (&cert);
|
||||||
if (!cert)
|
if (rc)
|
||||||
{
|
{
|
||||||
gpg_error_t tmperr = out_of_core ();
|
|
||||||
sc_pkcs15_free_certificate (certder);
|
sc_pkcs15_free_certificate (certder);
|
||||||
return tmperr;
|
return rc;
|
||||||
}
|
}
|
||||||
krc = ksba_cert_init_from_mem (cert, certder->data, certder->data_len);
|
krc = ksba_cert_init_from_mem (cert, certder->data, certder->data_len);
|
||||||
sc_pkcs15_free_certificate (certder);
|
sc_pkcs15_free_certificate (certder);
|
||||||
if (krc)
|
if (krc)
|
||||||
{
|
{
|
||||||
log_error ("failed to parse the certificate for private key %d: %s\n",
|
log_error ("failed to parse the certificate for private key %d: %s\n",
|
||||||
idx, ksba_strerror (krc));
|
idx, gpg_strerror (krc));
|
||||||
ksba_cert_release (cert);
|
ksba_cert_release (cert);
|
||||||
return gpg_error (GPG_ERR_CARD);
|
return krc;
|
||||||
}
|
}
|
||||||
if (card_help_get_keygrip (cert, keygrip))
|
if (card_help_get_keygrip (cert, keygrip))
|
||||||
{
|
{
|
||||||
|
@ -28,9 +28,10 @@
|
|||||||
#ifdef HAVE_OPENSC
|
#ifdef HAVE_OPENSC
|
||||||
#include <opensc/pkcs15.h>
|
#include <opensc/pkcs15.h>
|
||||||
#endif
|
#endif
|
||||||
#include <ksba.h>
|
|
||||||
|
|
||||||
#include "scdaemon.h"
|
#include "scdaemon.h"
|
||||||
|
#include <ksba.h>
|
||||||
|
|
||||||
#include "card-common.h"
|
#include "card-common.h"
|
||||||
|
|
||||||
/* Map the SC error codes to the GNUPG ones */
|
/* Map the SC error codes to the GNUPG ones */
|
||||||
|
@ -25,11 +25,11 @@
|
|||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <ksba.h>
|
|
||||||
|
|
||||||
#include <assuan.h>
|
#include <assuan.h>
|
||||||
|
|
||||||
#include "scdaemon.h"
|
#include "scdaemon.h"
|
||||||
|
#include <ksba.h>
|
||||||
#include "app-common.h"
|
#include "app-common.h"
|
||||||
|
|
||||||
/* maximum length aloowed as a PIN; used for INQUIRE NEEDPIN */
|
/* maximum length aloowed as a PIN; used for INQUIRE NEEDPIN */
|
||||||
@ -453,18 +453,16 @@ cmd_readkey (ASSUAN_CONTEXT ctx, char *line)
|
|||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
kc = ksba_cert_new ();
|
rc = ksba_cert_new (&kc);
|
||||||
if (!kc)
|
if (rc)
|
||||||
{
|
{
|
||||||
rc = out_of_core ();
|
|
||||||
xfree (cert);
|
xfree (cert);
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
rc = ksba_cert_init_from_mem (kc, cert, ncert);
|
rc = ksba_cert_init_from_mem (kc, cert, ncert);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("failed to parse the certificate: %s\n", ksba_strerror (rc));
|
log_error ("failed to parse the certificate: %s\n", gpg_strerror (rc));
|
||||||
rc = map_ksba_err (rc);
|
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -531,7 +529,7 @@ pin_cb (void *opaque, const char *info, char **retstr)
|
|||||||
ASSUAN_CONTEXT ctx = opaque;
|
ASSUAN_CONTEXT ctx = opaque;
|
||||||
char *command;
|
char *command;
|
||||||
int rc;
|
int rc;
|
||||||
char *value;
|
unsigned char *value;
|
||||||
size_t valuelen;
|
size_t valuelen;
|
||||||
|
|
||||||
*retstr = NULL;
|
*retstr = NULL;
|
||||||
|
@ -1,3 +1,7 @@
|
|||||||
|
2003-11-12 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
|
Adjusted for API changes in Libksba.
|
||||||
|
|
||||||
2003-10-31 Werner Koch <wk@gnupg.org>
|
2003-10-31 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
* certchain.c (gpgsm_validate_chain): Changed to use ksba_isotime_t.
|
* certchain.c (gpgsm_validate_chain): Changed to use ksba_isotime_t.
|
||||||
|
21
sm/base64.c
21
sm/base64.c
@ -27,9 +27,10 @@
|
|||||||
#include <time.h>
|
#include <time.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
|
#include "gpgsm.h"
|
||||||
|
|
||||||
#include <ksba.h>
|
#include <ksba.h>
|
||||||
|
|
||||||
#include "gpgsm.h"
|
|
||||||
#include "i18n.h"
|
#include "i18n.h"
|
||||||
|
|
||||||
#ifdef HAVE_DOSISH_SYSTEM
|
#ifdef HAVE_DOSISH_SYSTEM
|
||||||
@ -427,7 +428,7 @@ base64_writer_cb (void *cb_value, const void *buffer, size_t count)
|
|||||||
parm->base64.idx = idx;
|
parm->base64.idx = idx;
|
||||||
parm->base64.quad_count = quad_count;
|
parm->base64.quad_count = quad_count;
|
||||||
|
|
||||||
return ferror (fp) ? KSBA_Write_Error:0;
|
return ferror (fp) ? gpg_error_from_errno (errno) : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -506,11 +507,11 @@ gpgsm_create_reader (Base64Context *ctx,
|
|||||||
if (!*ctx)
|
if (!*ctx)
|
||||||
return OUT_OF_CORE (errno);
|
return OUT_OF_CORE (errno);
|
||||||
|
|
||||||
r = ksba_reader_new ();
|
rc = ksba_reader_new (&r);
|
||||||
if (!r)
|
if (rc)
|
||||||
{
|
{
|
||||||
xfree (*ctx); *ctx = NULL;
|
xfree (*ctx); *ctx = NULL;
|
||||||
return gpg_error (GPG_ERR_ENOMEM);
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
(*ctx)->u.rparm.fp = fp;
|
(*ctx)->u.rparm.fp = fp;
|
||||||
@ -537,7 +538,7 @@ gpgsm_create_reader (Base64Context *ctx,
|
|||||||
{
|
{
|
||||||
ksba_reader_release (r);
|
ksba_reader_release (r);
|
||||||
xfree (*ctx); *ctx = NULL;
|
xfree (*ctx); *ctx = NULL;
|
||||||
return map_ksba_err (rc);
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
*r_reader = r;
|
*r_reader = r;
|
||||||
@ -571,11 +572,11 @@ gpgsm_create_writer (Base64Context *ctx,
|
|||||||
if (!*ctx)
|
if (!*ctx)
|
||||||
return OUT_OF_CORE (errno);
|
return OUT_OF_CORE (errno);
|
||||||
|
|
||||||
w = ksba_writer_new ();
|
rc = ksba_writer_new (&w);
|
||||||
if (!w)
|
if (rc)
|
||||||
{
|
{
|
||||||
xfree (*ctx); *ctx = NULL;
|
xfree (*ctx); *ctx = NULL;
|
||||||
return gpg_error (GPG_ERR_ENOMEM);
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ctrl->create_pem || ctrl->create_base64)
|
if (ctrl->create_pem || ctrl->create_base64)
|
||||||
@ -593,7 +594,7 @@ gpgsm_create_writer (Base64Context *ctx,
|
|||||||
{
|
{
|
||||||
ksba_writer_release (w);
|
ksba_writer_release (w);
|
||||||
xfree (*ctx); *ctx = NULL;
|
xfree (*ctx); *ctx = NULL;
|
||||||
return map_ksba_err (rc);
|
return rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
*r_writer = w;
|
*r_writer = w;
|
||||||
|
@ -622,18 +622,18 @@ learn_cb (void *opaque, const void *buffer, size_t length)
|
|||||||
|
|
||||||
|
|
||||||
/* FIXME: this should go into import.c */
|
/* FIXME: this should go into import.c */
|
||||||
cert = ksba_cert_new ();
|
rc = ksba_cert_new (&cert);
|
||||||
if (!cert)
|
if (rc)
|
||||||
{
|
{
|
||||||
parm->error = gpg_error (GPG_ERR_ENOMEM);
|
parm->error = rc;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
rc = ksba_cert_init_from_mem (cert, buf, len);
|
rc = ksba_cert_init_from_mem (cert, buf, len);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("failed to parse a certificate: %s\n", ksba_strerror (rc));
|
log_error ("failed to parse a certificate: %s\n", gpg_strerror (rc));
|
||||||
ksba_cert_release (cert);
|
ksba_cert_release (cert);
|
||||||
parm->error = map_ksba_err (rc);
|
parm->error = rc;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -357,16 +357,16 @@ lookup_cb (void *opaque, const void *buffer, size_t length)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
cert = ksba_cert_new ();
|
rc = ksba_cert_new (&cert);
|
||||||
if (!cert)
|
if (rc)
|
||||||
{
|
{
|
||||||
parm->error = gpg_error (GPG_ERR_ENOMEM);
|
parm->error = rc;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
rc = ksba_cert_init_from_mem (cert, buf, len);
|
rc = ksba_cert_init_from_mem (cert, buf, len);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("failed to parse a certificate: %s\n", ksba_strerror (rc));
|
log_error ("failed to parse a certificate: %s\n", gpg_strerror (rc));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
@ -62,7 +62,7 @@ unknown_criticals (KsbaCert cert)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (err && err != -1)
|
if (err && err != -1)
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
|
|
||||||
return rc;
|
return rc;
|
||||||
}
|
}
|
||||||
@ -75,7 +75,7 @@ allowed_ca (KsbaCert cert, int *chainlen)
|
|||||||
|
|
||||||
err = ksba_cert_is_ca (cert, &flag, chainlen);
|
err = ksba_cert_is_ca (cert, &flag, chainlen);
|
||||||
if (err)
|
if (err)
|
||||||
return map_ksba_err (err);
|
return err;
|
||||||
if (!flag)
|
if (!flag)
|
||||||
{
|
{
|
||||||
log_error (_("issuer certificate is not marked as a CA\n"));
|
log_error (_("issuer certificate is not marked as a CA\n"));
|
||||||
@ -94,10 +94,10 @@ check_cert_policy (KsbaCert cert)
|
|||||||
int any_critical;
|
int any_critical;
|
||||||
|
|
||||||
err = ksba_cert_get_cert_policies (cert, &policies);
|
err = ksba_cert_get_cert_policies (cert, &policies);
|
||||||
if (err == KSBA_No_Data)
|
if (gpg_err_code (err) == GPG_ERR_NO_DATA)
|
||||||
return 0; /* no policy given */
|
return 0; /* no policy given */
|
||||||
if (err)
|
if (err)
|
||||||
return map_ksba_err (err);
|
return err;
|
||||||
|
|
||||||
/* STRING is a line delimited list of certifiate policies as stored
|
/* STRING is a line delimited list of certifiate policies as stored
|
||||||
in the certificate. The line itself is colon delimited where the
|
in the certificate. The line itself is colon delimited where the
|
||||||
@ -471,7 +471,7 @@ gpgsm_validate_chain (CTRL ctrl, KsbaCert cert, ksba_isotime_t r_exptime)
|
|||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error (_("certificate with invalid validity: %s\n"),
|
log_error (_("certificate with invalid validity: %s\n"),
|
||||||
ksba_strerror (rc));
|
gpg_strerror (rc));
|
||||||
rc = gpg_error (GPG_ERR_BAD_CERT);
|
rc = gpg_error (GPG_ERR_BAD_CERT);
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
@ -522,7 +522,7 @@ gpgsm_validate_chain (CTRL ctrl, KsbaCert cert, ksba_isotime_t r_exptime)
|
|||||||
rc = gpgsm_dirmngr_isvalid (subject_cert);
|
rc = gpgsm_dirmngr_isvalid (subject_cert);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
switch (rc)
|
switch (gpg_err_code (rc))
|
||||||
{
|
{
|
||||||
case GPG_ERR_CERT_REVOKED:
|
case GPG_ERR_CERT_REVOKED:
|
||||||
log_error (_("the certificate has been revoked\n"));
|
log_error (_("the certificate has been revoked\n"));
|
||||||
|
@ -129,9 +129,9 @@ gpgsm_check_cert_sig (KsbaCert issuer_cert, KsbaCert cert)
|
|||||||
rc = ksba_cert_hash (cert, 1, HASH_FNC, md);
|
rc = ksba_cert_hash (cert, 1, HASH_FNC, md);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cert_hash failed: %s\n", ksba_strerror (rc));
|
log_error ("ksba_cert_hash failed: %s\n", gpg_strerror (rc));
|
||||||
gcry_md_close (md);
|
gcry_md_close (md);
|
||||||
return map_ksba_err (rc);
|
return rc;
|
||||||
}
|
}
|
||||||
gcry_md_final (md);
|
gcry_md_final (md);
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ cert_usage_p (KsbaCert cert, int mode)
|
|||||||
unsigned int use;
|
unsigned int use;
|
||||||
|
|
||||||
err = ksba_cert_get_key_usage (cert, &use);
|
err = ksba_cert_get_key_usage (cert, &use);
|
||||||
if (err == KSBA_No_Data)
|
if (gpg_err_code (err) == GPG_ERR_NO_DATA)
|
||||||
{
|
{
|
||||||
if (opt.verbose && mode < 2)
|
if (opt.verbose && mode < 2)
|
||||||
log_info (mode?
|
log_info (mode?
|
||||||
@ -56,8 +56,8 @@ cert_usage_p (KsbaCert cert, int mode)
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error (_("error getting key usage information: %s\n"),
|
log_error (_("error getting key usage information: %s\n"),
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
return map_ksba_err (err);
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (mode == 4)
|
if (mode == 4)
|
||||||
|
@ -513,9 +513,9 @@ create_request (struct para_data_s *para, KsbaConstSexp public,
|
|||||||
int rc = 0;
|
int rc = 0;
|
||||||
const char *s;
|
const char *s;
|
||||||
|
|
||||||
cr = ksba_certreq_new ();
|
err = ksba_certreq_new (&cr);
|
||||||
if (!cr)
|
if (err)
|
||||||
return gpg_error (GPG_ERR_ENOMEM);
|
return err;
|
||||||
|
|
||||||
rc = gcry_md_open (&md, GCRY_MD_SHA1, 0);
|
rc = gcry_md_open (&md, GCRY_MD_SHA1, 0);
|
||||||
if (rc)
|
if (rc)
|
||||||
@ -533,8 +533,8 @@ create_request (struct para_data_s *para, KsbaConstSexp public,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("error setting the subject's name: %s\n",
|
log_error ("error setting the subject's name: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -557,8 +557,8 @@ create_request (struct para_data_s *para, KsbaConstSexp public,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("error setting the subject's alternate name: %s\n",
|
log_error ("error setting the subject's alternate name: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -568,8 +568,8 @@ create_request (struct para_data_s *para, KsbaConstSexp public,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("error setting the public key: %s\n",
|
log_error ("error setting the public key: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -578,8 +578,8 @@ create_request (struct para_data_s *para, KsbaConstSexp public,
|
|||||||
err = ksba_certreq_build (cr, &stopreason);
|
err = ksba_certreq_build (cr, &stopreason);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_certreq_build failed: %s\n", ksba_strerror (err));
|
log_error ("ksba_certreq_build failed: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
if (stopreason == KSBA_SR_NEED_SIG)
|
if (stopreason == KSBA_SR_NEED_SIG)
|
||||||
@ -630,8 +630,8 @@ create_request (struct para_data_s *para, KsbaConstSexp public,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("failed to store the sig_val: %s\n",
|
log_error ("failed to store the sig_val: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
30
sm/decrypt.c
30
sm/decrypt.c
@ -159,10 +159,10 @@ decrypt_filter (void *arg,
|
|||||||
|
|
||||||
/* fixme: Should we issue an error when we have not seen one full block? */
|
/* fixme: Should we issue an error when we have not seen one full block? */
|
||||||
if (!inlen)
|
if (!inlen)
|
||||||
return KSBA_Bug;
|
return gpg_error (GPG_ERR_BUG);
|
||||||
|
|
||||||
if (maxoutlen < 2*parm->blklen)
|
if (maxoutlen < 2*parm->blklen)
|
||||||
return KSBA_Bug;
|
return gpg_error (GPG_ERR_BUG);
|
||||||
/* make some space becuase we will later need an extra block at the end */
|
/* make some space becuase we will later need an extra block at the end */
|
||||||
maxoutlen -= blklen;
|
maxoutlen -= blklen;
|
||||||
|
|
||||||
@ -174,7 +174,7 @@ decrypt_filter (void *arg,
|
|||||||
parm->helpblock[i] = ((const char*)inbuf)[j];
|
parm->helpblock[i] = ((const char*)inbuf)[j];
|
||||||
inlen -= j;
|
inlen -= j;
|
||||||
if (blklen > maxoutlen)
|
if (blklen > maxoutlen)
|
||||||
return KSBA_Bug;
|
return gpg_error (GPG_ERR_BUG);
|
||||||
if (i < blklen)
|
if (i < blklen)
|
||||||
{
|
{
|
||||||
parm->helpblocklen = i;
|
parm->helpblocklen = i;
|
||||||
@ -285,10 +285,10 @@ gpgsm_decrypt (CTRL ctrl, int in_fd, FILE *out_fp)
|
|||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
cms = ksba_cms_new ();
|
err = ksba_cms_new (&cms);
|
||||||
if (!cms)
|
if (err)
|
||||||
{
|
{
|
||||||
rc = gpg_error (GPG_ERR_ENOMEM);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -296,8 +296,8 @@ gpgsm_decrypt (CTRL ctrl, int in_fd, FILE *out_fp)
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_debug ("ksba_cms_set_reader_writer failed: %s\n",
|
log_debug ("ksba_cms_set_reader_writer failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -307,8 +307,8 @@ gpgsm_decrypt (CTRL ctrl, int in_fd, FILE *out_fp)
|
|||||||
err = ksba_cms_parse (cms, &stopreason);
|
err = ksba_cms_parse (cms, &stopreason);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_debug ("ksba_cms_parse failed: %s\n", ksba_strerror (err));
|
log_debug ("ksba_cms_parse failed: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -352,8 +352,8 @@ gpgsm_decrypt (CTRL ctrl, int in_fd, FILE *out_fp)
|
|||||||
&dfparm.ivlen);
|
&dfparm.ivlen);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("error getting IV: %s\n", ksba_strerror (err));
|
log_error ("error getting IV: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -369,7 +369,7 @@ gpgsm_decrypt (CTRL ctrl, int in_fd, FILE *out_fp)
|
|||||||
break; /* no more recipients */
|
break; /* no more recipients */
|
||||||
if (err)
|
if (err)
|
||||||
log_error ("recp %d - error getting info: %s\n",
|
log_error ("recp %d - error getting info: %s\n",
|
||||||
recp, ksba_strerror (err));
|
recp, gpg_strerror (err));
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
KsbaCert cert = NULL;
|
KsbaCert cert = NULL;
|
||||||
@ -461,10 +461,8 @@ gpgsm_decrypt (CTRL ctrl, int in_fd, FILE *out_fp)
|
|||||||
dfparm.lastblock,
|
dfparm.lastblock,
|
||||||
dfparm.blklen - npadding);
|
dfparm.blklen - npadding);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
|
||||||
rc = map_ksba_err (rc);
|
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
|
||||||
for (i=dfparm.blklen - npadding; i < dfparm.blklen; i++)
|
for (i=dfparm.blklen - npadding; i < dfparm.blklen; i++)
|
||||||
{
|
{
|
||||||
if (dfparm.lastblock[i] != npadding)
|
if (dfparm.lastblock[i] != npadding)
|
||||||
|
40
sm/encrypt.c
40
sm/encrypt.c
@ -330,16 +330,14 @@ gpgsm_encrypt (CTRL ctrl, CERTLIST recplist, int data_fd, FILE *out_fp)
|
|||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
reader = ksba_reader_new ();
|
err = ksba_reader_new (&reader);
|
||||||
if (!reader)
|
if (err)
|
||||||
rc = KSBA_Out_Of_Core;
|
rc = err;
|
||||||
if (!rc)
|
if (!rc)
|
||||||
rc = ksba_reader_set_cb (reader, encrypt_cb, &encparm);
|
rc = ksba_reader_set_cb (reader, encrypt_cb, &encparm);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
|
||||||
rc = map_ksba_err (rc);
|
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
|
||||||
encparm.fp = data_fp;
|
encparm.fp = data_fp;
|
||||||
|
|
||||||
ctrl->pem_name = "ENCRYPTED MESSAGE";
|
ctrl->pem_name = "ENCRYPTED MESSAGE";
|
||||||
@ -350,10 +348,10 @@ gpgsm_encrypt (CTRL ctrl, CERTLIST recplist, int data_fd, FILE *out_fp)
|
|||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
cms = ksba_cms_new ();
|
err = ksba_cms_new (&cms);
|
||||||
if (!cms)
|
if (err)
|
||||||
{
|
{
|
||||||
rc = gpg_error (GPG_ERR_ENOMEM);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -361,8 +359,8 @@ gpgsm_encrypt (CTRL ctrl, CERTLIST recplist, int data_fd, FILE *out_fp)
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_debug ("ksba_cms_set_reader_writer failed: %s\n",
|
log_debug ("ksba_cms_set_reader_writer failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -374,8 +372,8 @@ gpgsm_encrypt (CTRL ctrl, CERTLIST recplist, int data_fd, FILE *out_fp)
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_debug ("ksba_cms_set_content_type failed: %s\n",
|
log_debug ("ksba_cms_set_content_type failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -399,8 +397,8 @@ gpgsm_encrypt (CTRL ctrl, CERTLIST recplist, int data_fd, FILE *out_fp)
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_set_content_enc_algo failed: %s\n",
|
log_error ("ksba_cms_set_content_enc_algo failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -432,8 +430,8 @@ gpgsm_encrypt (CTRL ctrl, CERTLIST recplist, int data_fd, FILE *out_fp)
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_add_recipient failed: %s\n",
|
log_error ("ksba_cms_add_recipient failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
xfree (encval);
|
xfree (encval);
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
@ -443,8 +441,8 @@ gpgsm_encrypt (CTRL ctrl, CERTLIST recplist, int data_fd, FILE *out_fp)
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_set_enc_val failed: %s\n",
|
log_error ("ksba_cms_set_enc_val failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -456,8 +454,8 @@ gpgsm_encrypt (CTRL ctrl, CERTLIST recplist, int data_fd, FILE *out_fp)
|
|||||||
err = ksba_cms_build (cms, &stopreason);
|
err = ksba_cms_build (cms, &stopreason);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_debug ("ksba_cms_build failed: %s\n", ksba_strerror (err));
|
log_debug ("ksba_cms_build failed: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -155,7 +155,7 @@ gpgsm_export (CTRL ctrl, STRLIST names, FILE *fp)
|
|||||||
rc = ksba_writer_write (writer, image, imagelen);
|
rc = ksba_writer_write (writer, image, imagelen);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("write error: %s\n", ksba_strerror (rc));
|
log_error ("write error: %s\n", gpg_strerror (rc));
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,7 +70,7 @@ gpgsm_get_fingerprint (KsbaCert cert, int algo, char *array, int *r_len)
|
|||||||
rc = ksba_cert_hash (cert, 0, HASH_FNC, md);
|
rc = ksba_cert_hash (cert, 0, HASH_FNC, md);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cert_hash failed: %s\n", ksba_strerror (rc));
|
log_error ("ksba_cert_hash failed: %s\n", gpg_strerror (rc));
|
||||||
gcry_md_close (md);
|
gcry_md_close (md);
|
||||||
memset (array, 0xff, len); /* better return an invalid fpr than NULL */
|
memset (array, 0xff, len); /* better return an invalid fpr than NULL */
|
||||||
return array;
|
return array;
|
||||||
@ -204,7 +204,7 @@ gpgsm_get_keygrip_hexstring (KsbaCert cert)
|
|||||||
serial number for this. In most cases the serial number is not
|
serial number for this. In most cases the serial number is not
|
||||||
that large and the resulting string can be passed on an assuan
|
that large and the resulting string can be passed on an assuan
|
||||||
command line. Everything is hexencoded with the serialnumber
|
command line. Everything is hexencoded with the serialnumber
|
||||||
delimted from the has by a dot.
|
delimited from the hash by a dot.
|
||||||
|
|
||||||
The caller must free the string.
|
The caller must free the string.
|
||||||
*/
|
*/
|
||||||
|
29
sm/import.c
29
sm/import.c
@ -221,19 +221,15 @@ import_one (CTRL ctrl, struct stats_s *stats, int in_fd)
|
|||||||
KsbaStopReason stopreason;
|
KsbaStopReason stopreason;
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
cms = ksba_cms_new ();
|
rc = ksba_cms_new (&cms);
|
||||||
if (!cms)
|
if (rc)
|
||||||
{
|
goto leave;
|
||||||
rc = gpg_error (GPG_ERR_ENOMEM);
|
|
||||||
goto leave;
|
|
||||||
}
|
|
||||||
|
|
||||||
rc = ksba_cms_set_reader_writer (cms, reader, NULL);
|
rc = ksba_cms_set_reader_writer (cms, reader, NULL);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_set_reader_writer failed: %s\n",
|
log_error ("ksba_cms_set_reader_writer failed: %s\n",
|
||||||
ksba_strerror (rc));
|
gpg_strerror (rc));
|
||||||
rc = map_ksba_err (rc);
|
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -243,8 +239,7 @@ import_one (CTRL ctrl, struct stats_s *stats, int in_fd)
|
|||||||
rc = ksba_cms_parse (cms, &stopreason);
|
rc = ksba_cms_parse (cms, &stopreason);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_parse failed: %s\n", ksba_strerror (rc));
|
log_error ("ksba_cms_parse failed: %s\n", gpg_strerror (rc));
|
||||||
rc = map_ksba_err (rc);
|
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -265,19 +260,13 @@ import_one (CTRL ctrl, struct stats_s *stats, int in_fd)
|
|||||||
else if (ct == KSBA_CT_NONE)
|
else if (ct == KSBA_CT_NONE)
|
||||||
{ /* Failed to identify this message - assume a certificate */
|
{ /* Failed to identify this message - assume a certificate */
|
||||||
|
|
||||||
cert = ksba_cert_new ();
|
rc = ksba_cert_new (&cert);
|
||||||
if (!cert)
|
if (rc)
|
||||||
{
|
goto leave;
|
||||||
rc = gpg_error (GPG_ERR_ENOMEM);
|
|
||||||
goto leave;
|
|
||||||
}
|
|
||||||
|
|
||||||
rc = ksba_cert_read_der (cert, reader);
|
rc = ksba_cert_read_der (cert, reader);
|
||||||
if (rc)
|
if (rc)
|
||||||
{
|
goto leave;
|
||||||
rc = map_ksba_err (rc);
|
|
||||||
goto leave;
|
|
||||||
}
|
|
||||||
|
|
||||||
check_and_store (ctrl, stats, cert, 0);
|
check_and_store (ctrl, stats, cert, 0);
|
||||||
}
|
}
|
||||||
|
14
sm/keylist.c
14
sm/keylist.c
@ -68,7 +68,7 @@ print_capabilities (KsbaCert cert, FILE *fp)
|
|||||||
unsigned int use;
|
unsigned int use;
|
||||||
|
|
||||||
err = ksba_cert_get_key_usage (cert, &use);
|
err = ksba_cert_get_key_usage (cert, &use);
|
||||||
if (err == KSBA_No_Data)
|
if (gpg_err_code (err) == GPG_ERR_NO_DATA)
|
||||||
{
|
{
|
||||||
putc ('e', fp);
|
putc ('e', fp);
|
||||||
putc ('s', fp);
|
putc ('s', fp);
|
||||||
@ -81,7 +81,7 @@ print_capabilities (KsbaCert cert, FILE *fp)
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error (_("error getting key usage information: %s\n"),
|
log_error (_("error getting key usage information: %s\n"),
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -328,11 +328,11 @@ list_cert_std (KsbaCert cert, FILE *fp, int have_secret)
|
|||||||
putc ('\n', fp);
|
putc ('\n', fp);
|
||||||
|
|
||||||
kerr = ksba_cert_get_key_usage (cert, &kusage);
|
kerr = ksba_cert_get_key_usage (cert, &kusage);
|
||||||
if (kerr != KSBA_No_Data)
|
if (gpg_err_code (kerr) != GPG_ERR_NO_DATA)
|
||||||
{
|
{
|
||||||
fputs (" key usage:", fp);
|
fputs (" key usage:", fp);
|
||||||
if (kerr)
|
if (kerr)
|
||||||
fprintf (fp, " [error: %s]", ksba_strerror (kerr));
|
fprintf (fp, " [error: %s]", gpg_strerror (kerr));
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
if ( (kusage & KSBA_KEYUSAGE_DIGITAL_SIGNATURE))
|
if ( (kusage & KSBA_KEYUSAGE_DIGITAL_SIGNATURE))
|
||||||
@ -358,11 +358,11 @@ list_cert_std (KsbaCert cert, FILE *fp, int have_secret)
|
|||||||
}
|
}
|
||||||
|
|
||||||
kerr = ksba_cert_get_cert_policies (cert, &string);
|
kerr = ksba_cert_get_cert_policies (cert, &string);
|
||||||
if (kerr != KSBA_No_Data)
|
if (gpg_err_code (kerr) != GPG_ERR_NO_DATA)
|
||||||
{
|
{
|
||||||
fputs (" policies: ", fp);
|
fputs (" policies: ", fp);
|
||||||
if (kerr)
|
if (kerr)
|
||||||
fprintf (fp, "[error: %s]", ksba_strerror (kerr));
|
fprintf (fp, "[error: %s]", gpg_strerror (kerr));
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
for (p=string; *p; p++)
|
for (p=string; *p; p++)
|
||||||
@ -381,7 +381,7 @@ list_cert_std (KsbaCert cert, FILE *fp, int have_secret)
|
|||||||
{
|
{
|
||||||
fputs (" chain length: ", fp);
|
fputs (" chain length: ", fp);
|
||||||
if (kerr)
|
if (kerr)
|
||||||
fprintf (fp, "[error: %s]", ksba_strerror (kerr));
|
fprintf (fp, "[error: %s]", gpg_strerror (kerr));
|
||||||
else if (chainlen == -1)
|
else if (chainlen == -1)
|
||||||
fputs ("unlimited", fp);
|
fputs ("unlimited", fp);
|
||||||
else
|
else
|
||||||
|
@ -26,7 +26,8 @@
|
|||||||
#include <ctype.h>
|
#include <ctype.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include <ksba.h>
|
|
||||||
|
|
||||||
#include "gpgsm.h"
|
#include "gpgsm.h"
|
||||||
|
|
||||||
|
#include <ksba.h>
|
||||||
|
|
||||||
|
|
||||||
|
56
sm/sign.c
56
sm/sign.c
@ -88,8 +88,8 @@ hash_and_copy_data (int fd, gcry_md_hd_t md, KsbaWriter writer)
|
|||||||
err = ksba_writer_write_octet_string (writer, buffer, nread, 0);
|
err = ksba_writer_write_octet_string (writer, buffer, nread, 0);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("write failed: %s\n", ksba_strerror (err));
|
log_error ("write failed: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -114,8 +114,8 @@ hash_and_copy_data (int fd, gcry_md_hd_t md, KsbaWriter writer)
|
|||||||
err = ksba_writer_write_octet_string (writer, NULL, 0, 1);
|
err = ksba_writer_write_octet_string (writer, NULL, 0, 1);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("write failed: %s\n", ksba_strerror (err));
|
log_error ("write failed: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -278,8 +278,8 @@ add_certificate_list (CTRL ctrl, KsbaCMS cms, KsbaCert cert)
|
|||||||
|
|
||||||
ksba_failure:
|
ksba_failure:
|
||||||
ksba_cert_release (cert);
|
ksba_cert_release (cert);
|
||||||
log_error ("ksba_cms_add_cert failed: %s\n", ksba_strerror (err));
|
log_error ("ksba_cms_add_cert failed: %s\n", gpg_strerror (err));
|
||||||
return map_ksba_err (err);
|
return err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -326,10 +326,10 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
cms = ksba_cms_new ();
|
err = ksba_cms_new (&cms);
|
||||||
if (!cms)
|
if (err)
|
||||||
{
|
{
|
||||||
rc = gpg_error (GPG_ERR_ENOMEM);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -337,8 +337,8 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_debug ("ksba_cms_set_reader_writer failed: %s\n",
|
log_debug ("ksba_cms_set_reader_writer failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -349,8 +349,8 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_debug ("ksba_cms_set_content_type failed: %s\n",
|
log_debug ("ksba_cms_set_content_type failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -386,8 +386,8 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
err = ksba_cms_add_signer (cms, cl->cert);
|
err = ksba_cms_add_signer (cms, cl->cert);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_add_signer failed: %s\n", ksba_strerror (err));
|
log_error ("ksba_cms_add_signer failed: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
rc = add_certificate_list (ctrl, cms, cl->cert);
|
rc = add_certificate_list (ctrl, cms, cl->cert);
|
||||||
@ -402,8 +402,8 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_debug ("ksba_cms_add_digest_algo failed: %s\n",
|
log_debug ("ksba_cms_add_digest_algo failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -455,8 +455,8 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_set_message_digest failed: %s\n",
|
log_error ("ksba_cms_set_message_digest failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -469,8 +469,8 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_set_signing_time failed: %s\n",
|
log_error ("ksba_cms_set_signing_time failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -480,8 +480,8 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
err = ksba_cms_build (cms, &stopreason);
|
err = ksba_cms_build (cms, &stopreason);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_debug ("ksba_cms_build failed: %s\n", ksba_strerror (err));
|
log_debug ("ksba_cms_build failed: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -515,8 +515,8 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_set_message_digest failed: %s\n",
|
log_error ("ksba_cms_set_message_digest failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -546,7 +546,7 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_debug ("hashing signed attrs failed: %s\n",
|
log_debug ("hashing signed attrs failed: %s\n",
|
||||||
ksba_strerror (rc));
|
gpg_strerror (rc));
|
||||||
gcry_md_close (md);
|
gcry_md_close (md);
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
@ -563,8 +563,8 @@ gpgsm_sign (CTRL ctrl, CERTLIST signerlist,
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("failed to store the signature: %s\n",
|
log_error ("failed to store the signature: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
gcry_md_close (md);
|
gcry_md_close (md);
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
31
sm/verify.c
31
sm/verify.c
@ -135,8 +135,8 @@ gpgsm_verify (CTRL ctrl, int in_fd, int data_fd, FILE *out_fp)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
cms = ksba_cms_new ();
|
err = ksba_cms_new (&cms);
|
||||||
if (!cms)
|
if (err)
|
||||||
{
|
{
|
||||||
rc = gpg_error (GPG_ERR_ENOMEM);
|
rc = gpg_error (GPG_ERR_ENOMEM);
|
||||||
goto leave;
|
goto leave;
|
||||||
@ -146,8 +146,8 @@ gpgsm_verify (CTRL ctrl, int in_fd, int data_fd, FILE *out_fp)
|
|||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_set_reader_writer failed: %s\n",
|
log_error ("ksba_cms_set_reader_writer failed: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -166,8 +166,8 @@ gpgsm_verify (CTRL ctrl, int in_fd, int data_fd, FILE *out_fp)
|
|||||||
err = ksba_cms_parse (cms, &stopreason);
|
err = ksba_cms_parse (cms, &stopreason);
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{
|
||||||
log_error ("ksba_cms_parse failed: %s\n", ksba_strerror (err));
|
log_error ("ksba_cms_parse failed: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (err);
|
rc = err;
|
||||||
goto leave;
|
goto leave;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -250,7 +250,8 @@ gpgsm_verify (CTRL ctrl, int in_fd, int data_fd, FILE *out_fp)
|
|||||||
char *ctattr;
|
char *ctattr;
|
||||||
|
|
||||||
err = ksba_cms_get_issuer_serial (cms, signer, &issuer, &serial);
|
err = ksba_cms_get_issuer_serial (cms, signer, &issuer, &serial);
|
||||||
if (!signer && err == KSBA_No_Data && data_fd == -1 && is_detached)
|
if (!signer && gpg_err_code (err) == GPG_ERR_NO_DATA
|
||||||
|
&& data_fd == -1 && is_detached)
|
||||||
{
|
{
|
||||||
log_info ("certs-only message accepted\n");
|
log_info ("certs-only message accepted\n");
|
||||||
err = 0;
|
err = 0;
|
||||||
@ -272,11 +273,11 @@ gpgsm_verify (CTRL ctrl, int in_fd, int data_fd, FILE *out_fp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
err = ksba_cms_get_signing_time (cms, signer, sigtime);
|
err = ksba_cms_get_signing_time (cms, signer, sigtime);
|
||||||
if (err == KSBA_No_Data)
|
if (gpg_err_code (err) == GPG_ERR_NO_DATA)
|
||||||
*sigtime = 0;
|
*sigtime = 0;
|
||||||
else if (err)
|
else if (err)
|
||||||
{
|
{
|
||||||
log_error ("error getting signing time: %s\n", ksba_strerror (err));
|
log_error ("error getting signing time: %s\n", gpg_strerror (err));
|
||||||
*sigtime = 0; /* FIXME: we can't encode an error in the time
|
*sigtime = 0; /* FIXME: we can't encode an error in the time
|
||||||
string. */
|
string. */
|
||||||
}
|
}
|
||||||
@ -295,7 +296,7 @@ gpgsm_verify (CTRL ctrl, int in_fd, int data_fd, FILE *out_fp)
|
|||||||
goto next_signer;
|
goto next_signer;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (err == KSBA_No_Data)
|
else if (gpg_err_code (err) == GPG_ERR_NO_DATA)
|
||||||
{
|
{
|
||||||
assert (!msgdigest);
|
assert (!msgdigest);
|
||||||
err = 0;
|
err = 0;
|
||||||
@ -328,7 +329,7 @@ gpgsm_verify (CTRL ctrl, int in_fd, int data_fd, FILE *out_fp)
|
|||||||
else if (err != -1)
|
else if (err != -1)
|
||||||
{
|
{
|
||||||
log_error ("error getting content-type attribute: %s\n",
|
log_error ("error getting content-type attribute: %s\n",
|
||||||
ksba_strerror (err));
|
gpg_strerror (err));
|
||||||
goto next_signer;
|
goto next_signer;
|
||||||
}
|
}
|
||||||
err = 0;
|
err = 0;
|
||||||
@ -420,7 +421,7 @@ gpgsm_verify (CTRL ctrl, int in_fd, int data_fd, FILE *out_fp)
|
|||||||
if (rc)
|
if (rc)
|
||||||
{
|
{
|
||||||
log_error ("hashing signed attrs failed: %s\n",
|
log_error ("hashing signed attrs failed: %s\n",
|
||||||
ksba_strerror (rc));
|
gpg_strerror (rc));
|
||||||
gcry_md_close (md);
|
gcry_md_close (md);
|
||||||
goto next_signer;
|
goto next_signer;
|
||||||
}
|
}
|
||||||
@ -514,9 +515,9 @@ gpgsm_verify (CTRL ctrl, int in_fd, int data_fd, FILE *out_fp)
|
|||||||
}
|
}
|
||||||
rc = 0;
|
rc = 0;
|
||||||
if (err)
|
if (err)
|
||||||
{
|
{ /* FIXME: still needed? */
|
||||||
log_error ("ksba error: %s\n", ksba_strerror (err));
|
log_error ("ksba error: %s\n", gpg_strerror (err));
|
||||||
rc = map_ksba_err (rc);
|
rc = err;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user