mirror of
git://git.gnupg.org/gnupg.git
synced 2025-01-03 12:11:33 +01:00
* keylist.c (list_cert_colon): Print alternative names of subject
and a few other values.
This commit is contained in:
parent
e4f9871d91
commit
dda2440aea
@ -1,3 +1,8 @@
|
|||||||
|
2001-12-13 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
|
* keylist.c (list_cert_colon): Print alternative names of subject
|
||||||
|
and a few other values.
|
||||||
|
|
||||||
2001-12-12 Werner Koch <wk@gnupg.org>
|
2001-12-12 Werner Koch <wk@gnupg.org>
|
||||||
|
|
||||||
* gpgsm.c (main): New options --assume-{armor,base64,binary}.
|
* gpgsm.c (main): New options --assume-{armor,base64,binary}.
|
||||||
@ -38,5 +43,3 @@
|
|||||||
This file is distributed in the hope that it will be useful, but
|
This file is distributed in the hope that it will be useful, but
|
||||||
WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
|
WITHOUT ANY WARRANTY, to the extent permitted by law; without even the
|
||||||
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||||||
|
|
||||||
|
|
||||||
|
@ -58,8 +58,8 @@ gpgsm_validate_path (KsbaCert cert)
|
|||||||
{
|
{
|
||||||
xfree (issuer);
|
xfree (issuer);
|
||||||
xfree (subject);
|
xfree (subject);
|
||||||
issuer = ksba_cert_get_issuer (subject_cert);
|
issuer = ksba_cert_get_issuer (subject_cert, 0);
|
||||||
subject = ksba_cert_get_subject (subject_cert);
|
subject = ksba_cert_get_subject (subject_cert, 0);
|
||||||
|
|
||||||
if (!issuer)
|
if (!issuer)
|
||||||
{
|
{
|
||||||
|
@ -103,13 +103,13 @@ gpgsm_dump_cert (const char *text, KsbaCert cert)
|
|||||||
print_time (t);
|
print_time (t);
|
||||||
log_printf ("\n");
|
log_printf ("\n");
|
||||||
|
|
||||||
dn = ksba_cert_get_issuer (cert);
|
dn = ksba_cert_get_issuer (cert, 0);
|
||||||
log_debug (" issuer: ");
|
log_debug (" issuer: ");
|
||||||
print_dn (dn);
|
print_dn (dn);
|
||||||
ksba_free (dn);
|
ksba_free (dn);
|
||||||
log_printf ("\n");
|
log_printf ("\n");
|
||||||
|
|
||||||
dn = ksba_cert_get_subject (cert);
|
dn = ksba_cert_get_subject (cert, 0);
|
||||||
log_debug (" subject: ");
|
log_debug (" subject: ");
|
||||||
print_dn (dn);
|
print_dn (dn);
|
||||||
ksba_free (dn);
|
ksba_free (dn);
|
||||||
|
@ -71,7 +71,7 @@ gpgsm_add_to_certlist (const char *name, CERTLIST *listaddr)
|
|||||||
|
|
||||||
keydb_release (kh);
|
keydb_release (kh);
|
||||||
ksba_cert_release (cert);
|
ksba_cert_release (cert);
|
||||||
return rc;
|
return rc == -1? GNUPG_No_Public_Key: rc;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
@ -58,8 +58,8 @@ gpgsm_validate_path (KsbaCert cert)
|
|||||||
{
|
{
|
||||||
xfree (issuer);
|
xfree (issuer);
|
||||||
xfree (subject);
|
xfree (subject);
|
||||||
issuer = ksba_cert_get_issuer (subject_cert);
|
issuer = ksba_cert_get_issuer (subject_cert, 0);
|
||||||
subject = ksba_cert_get_subject (subject_cert);
|
subject = ksba_cert_get_subject (subject_cert, 0);
|
||||||
|
|
||||||
if (!issuer)
|
if (!issuer)
|
||||||
{
|
{
|
||||||
|
57
sm/keylist.c
57
sm/keylist.c
@ -66,13 +66,24 @@ print_capabilities (KsbaCert cert, FILE *fp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
static void
|
||||||
|
print_time (time_t t, FILE *fp)
|
||||||
|
{
|
||||||
|
if (!t)
|
||||||
|
;
|
||||||
|
else if ( t == (time_t)(-1) )
|
||||||
|
putc ('?', fp);
|
||||||
|
else
|
||||||
|
fprintf (fp, "%lu", (unsigned long)t);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* List one certificate in colon mode */
|
/* List one certificate in colon mode */
|
||||||
static void
|
static void
|
||||||
list_cert_colon (KsbaCert cert, FILE *fp)
|
list_cert_colon (KsbaCert cert, FILE *fp)
|
||||||
{
|
{
|
||||||
int trustletter = 0;
|
int idx, trustletter = 0;
|
||||||
char *p;
|
unsigned char *p;
|
||||||
|
|
||||||
fputs ("crt:", fp);
|
fputs ("crt:", fp);
|
||||||
trustletter = 0;
|
trustletter = 0;
|
||||||
@ -90,35 +101,57 @@ list_cert_colon (KsbaCert cert, FILE *fp)
|
|||||||
putc (trustletter, fp);
|
putc (trustletter, fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf (fp, ":%u:%d::%s:%s:::",
|
fprintf (fp, ":%u:%d::",
|
||||||
/*keylen_of_cert (cert)*/1024,
|
/*keylen_of_cert (cert)*/1024,
|
||||||
/* pubkey_algo_of_cert (cert)*/'R',
|
/* pubkey_algo_of_cert (cert)*/'R');
|
||||||
/*colon_datestr_from_cert (cert)*/ "2001-11-11",
|
|
||||||
/*colon_strtime_expire (cert)*/ "2001-11-12" );
|
|
||||||
|
|
||||||
|
/* we assume --fixed-list-mode for gpgsm */
|
||||||
|
print_time ( ksba_cert_get_validity (cert, 0), fp);
|
||||||
putc (':', fp);
|
putc (':', fp);
|
||||||
/* fixme: should we print the issuer name here? */
|
print_time ( ksba_cert_get_validity (cert, 1), fp);
|
||||||
|
putc (':', fp);
|
||||||
|
putc (':', fp);
|
||||||
|
if ((p = ksba_cert_get_serial (cert)))
|
||||||
|
{
|
||||||
|
int i, len = (p[0] << 24) | (p[1] << 16) | (p[2] << 8) | p[3];
|
||||||
|
for (i=0; i < len; i++)
|
||||||
|
fprintf (fp,"%02X", p[4+i]);
|
||||||
|
xfree (p);
|
||||||
|
}
|
||||||
|
putc (':', fp);
|
||||||
|
putc (':', fp);
|
||||||
|
if ((p = ksba_cert_get_issuer (cert,0)))
|
||||||
|
{
|
||||||
|
fputs (p, fp); /* FIXME: Escape colons and linefeeds */
|
||||||
|
xfree (p);
|
||||||
|
}
|
||||||
putc (':', fp);
|
putc (':', fp);
|
||||||
print_capabilities (cert, fp);
|
print_capabilities (cert, fp);
|
||||||
putc ('\n', fp);
|
putc ('\n', fp);
|
||||||
|
|
||||||
p = gpgsm_get_fingerprint_hexstring (cert, GCRY_MD_SHA1);
|
p = gpgsm_get_fingerprint_hexstring (cert, GCRY_MD_SHA1);
|
||||||
fprintf (fp, "fpr:::::::::%s:\n", p);
|
fprintf (fp, "fpr:::::::::%s:\n", p);
|
||||||
xfree (p);
|
xfree (p);
|
||||||
p = gpgsm_get_keygrip_hexstring (cert);
|
|
||||||
fprintf (fp, "grp:::::::::%s:\n", p?p:"");
|
|
||||||
xfree (p);
|
|
||||||
if (opt.with_key_data)
|
if (opt.with_key_data)
|
||||||
|
{
|
||||||
|
if ( (p = gpgsm_get_keygrip_hexstring (cert)))
|
||||||
|
{
|
||||||
|
fprintf (fp, "grp:::::::::%s:\n", p);
|
||||||
|
xfree (p);
|
||||||
|
}
|
||||||
print_key_data (cert, fp);
|
print_key_data (cert, fp);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (idx=0; (p = ksba_cert_get_subject (cert,idx)); idx++)
|
||||||
|
{
|
||||||
fprintf (fp, "uid:%c::::::::", trustletter);
|
fprintf (fp, "uid:%c::::::::", trustletter);
|
||||||
p = ksba_cert_get_subject (cert);
|
|
||||||
if (p)
|
|
||||||
fputs (p, fp); /* FIXME: Escape colons and linefeeds */
|
fputs (p, fp); /* FIXME: Escape colons and linefeeds */
|
||||||
xfree (p);
|
xfree (p);
|
||||||
putc (':', fp);
|
putc (':', fp);
|
||||||
putc (':', fp);
|
putc (':', fp);
|
||||||
putc ('\n', fp);
|
putc ('\n', fp);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user