5 #include <credentials/keys/private_key.h>
6 #include <credentials/keys/public_key.h>
9 * print the keyids of a private or public key
11 int main(int argc
, char *argv
[])
14 private_key_t
*private;
20 lib
->plugins
->load(lib
->plugins
, IPSEC_PLUGINDIR
, "gmp pubkey sha1");
21 atexit(library_deinit
);
23 read
= fread(buf
, 1, sizeof(buf
), stdin
);
26 fprintf(stderr
, "reading key failed.\n");
30 chunk
= chunk_create(buf
, read
);
32 private = lib
->creds
->create(lib
->creds
, CRED_PRIVATE_KEY
, KEY_RSA
,
33 BUILD_BLOB_ASN1_DER
, chunk_clone(chunk
),
37 printf("parsed %d bits %N private key.\n",
38 private->get_keysize(private)*8,
39 key_type_names
, private->get_type(private));
40 if (private->get_fingerprint(private, KEY_ID_PUBKEY_INFO_SHA1
, &chunk
))
42 printf("subjectPublicKeyInfo keyid: %#B\n", &chunk
);
44 if (private->get_fingerprint(private, KEY_ID_PUBKEY_SHA1
, &chunk
))
46 printf("subjectPublicKey keyid: %#B\n", &chunk
);
48 if (private->get_fingerprint(private, KEY_ID_PGPV3
, &chunk
))
50 printf("PGP verison 3 keyid: %#B\n", &chunk
);
52 private->destroy(private);
56 public = lib
->creds
->create(lib
->creds
, CRED_PUBLIC_KEY
, KEY_ANY
,
57 BUILD_BLOB_ASN1_DER
, chunk_clone(chunk
),
61 public = lib
->creds
->create(lib
->creds
, CRED_PUBLIC_KEY
, KEY_RSA
,
62 BUILD_BLOB_ASN1_DER
, chunk_clone(chunk
),
67 printf("parsed %d bits %N public key.\n",
68 public->get_keysize(public)*8,
69 key_type_names
, public->get_type(public));
70 if (public->get_fingerprint(public, KEY_ID_PUBKEY_INFO_SHA1
, &chunk
))
72 printf("subjectPublicKeyInfo keyid: %#B\n", &chunk
);
74 if (public->get_fingerprint(public, KEY_ID_PUBKEY_SHA1
, &chunk
))
76 printf("subjectPublicKey keyid: %#B\n", &chunk
);
78 if (public->get_fingerprint(public, KEY_ID_PGPV3
, &chunk
))
80 printf("PGP verison 3 keyid: %#B\n", &chunk
);
82 public->destroy(public);
86 fprintf(stderr
, "unable to parse input key.\n");