aboutsummaryrefslogtreecommitdiffstats
path: root/src/libstrongswan/plugins/openssl/openssl_rsa_public_key.c
diff options
context:
space:
mode:
authorMartin Willi <martin@strongswan.org>2009-08-27 09:58:38 +0200
committerMartin Willi <martin@strongswan.org>2009-08-27 09:58:38 +0200
commitb12c6d163d179ad238fe920eb9f1746b96f51166 (patch)
tree417f9955630d710b543ce5289e308e0bb08a8a39 /src/libstrongswan/plugins/openssl/openssl_rsa_public_key.c
parent2ee8cd04bdeac33c893c9b20c82e465e03b5a769 (diff)
downloadstrongswan-b12c6d163d179ad238fe920eb9f1746b96f51166.tar.bz2
strongswan-b12c6d163d179ad238fe920eb9f1746b96f51166.tar.xz
do openssl fingerprinting/encoding directly, openssl provides all functions
Diffstat (limited to 'src/libstrongswan/plugins/openssl/openssl_rsa_public_key.c')
-rw-r--r--src/libstrongswan/plugins/openssl/openssl_rsa_public_key.c85
1 files changed, 61 insertions, 24 deletions
diff --git a/src/libstrongswan/plugins/openssl/openssl_rsa_public_key.c b/src/libstrongswan/plugins/openssl/openssl_rsa_public_key.c
index cb3e80a69..880a4613e 100644
--- a/src/libstrongswan/plugins/openssl/openssl_rsa_public_key.c
+++ b/src/libstrongswan/plugins/openssl/openssl_rsa_public_key.c
@@ -20,6 +20,7 @@
#include <openssl/evp.h>
#include <openssl/rsa.h>
+#include <openssl/x509.h>
typedef struct private_openssl_rsa_public_key_t private_openssl_rsa_public_key_t;
@@ -169,27 +170,53 @@ static size_t get_keysize(private_openssl_rsa_public_key_t *this)
}
/**
- * Implementation of public_key_t.get_fingerprint.
+ * Calculate fingerprint from a RSA key, also used in rsa private key.
*/
-static bool get_fingerprint(private_openssl_rsa_public_key_t *this,
- key_encoding_type_t type, chunk_t *fingerprint)
+bool openssl_rsa_fingerprint(RSA *rsa, key_encoding_type_t type, chunk_t *fp)
{
- chunk_t enc;
- bool success;
+ hasher_t *hasher;
+ chunk_t key;
u_char *p;
- if (lib->encoding->get_cache(lib->encoding, type, this, fingerprint))
+ if (lib->encoding->get_cache(lib->encoding, type, rsa, fp))
{
return TRUE;
}
- enc = chunk_alloc(i2d_RSAPublicKey(this->rsa, NULL));
- p = enc.ptr;
- i2d_RSAPublicKey(this->rsa, &p);
- success = lib->encoding->encode(lib->encoding, type, this, fingerprint,
- KEY_PART_RSA_PUB_ASN1_DER, enc, KEY_PART_END);
- free(enc.ptr);
-
- return success;
+ switch (type)
+ {
+ case KEY_ID_PUBKEY_SHA1:
+ key = chunk_alloc(i2d_RSAPublicKey(rsa, NULL));
+ p = key.ptr;
+ i2d_RSAPublicKey(rsa, &p);
+ break;
+ case KEY_ID_PUBKEY_INFO_SHA1:
+ key = chunk_alloc(i2d_RSA_PUBKEY(rsa, NULL));
+ p = key.ptr;
+ i2d_RSA_PUBKEY(rsa, &p);
+ break;
+ default:
+ return FALSE;
+ }
+ hasher = lib->crypto->create_hasher(lib->crypto, HASH_SHA1);
+ if (!hasher)
+ {
+ DBG1("SHA1 hash algorithm not supported, fingerprinting failed");
+ free(key.ptr);
+ return FALSE;
+ }
+ hasher->allocate_hash(hasher, key, fp);
+ hasher->destroy(hasher);
+ lib->encoding->cache(lib->encoding, type, rsa, *fp);
+ return TRUE;
+}
+
+/**
+ * Implementation of public_key_t.get_fingerprint.
+ */
+static bool get_fingerprint(private_openssl_rsa_public_key_t *this,
+ key_encoding_type_t type, chunk_t *fingerprint)
+{
+ return openssl_rsa_fingerprint(this->rsa, type, fingerprint);
}
/*
@@ -198,17 +225,27 @@ static bool get_fingerprint(private_openssl_rsa_public_key_t *this,
static bool get_encoding(private_openssl_rsa_public_key_t *this,
key_encoding_type_t type, chunk_t *encoding)
{
- chunk_t enc;
- bool success;
u_char *p;
- enc = chunk_alloc(i2d_RSAPublicKey(this->rsa, NULL));
- p = enc.ptr;
- i2d_RSAPublicKey(this->rsa, &p);
- success = lib->encoding->encode(lib->encoding, type, NULL, encoding,
- KEY_PART_RSA_PUB_ASN1_DER, enc, KEY_PART_END);
- free(enc.ptr);
- return success;
+ switch (type)
+ {
+ case KEY_PUB_SPKI_ASN1_DER:
+ {
+ *encoding = chunk_alloc(i2d_RSA_PUBKEY(this->rsa, NULL));
+ p = encoding->ptr;
+ i2d_RSA_PUBKEY(this->rsa, &p);
+ return TRUE;
+ }
+ case KEY_PUB_ASN1_DER:
+ {
+ *encoding = chunk_alloc(i2d_RSAPublicKey(this->rsa, NULL));
+ p = encoding->ptr;
+ i2d_RSAPublicKey(this->rsa, &p);
+ return TRUE;
+ }
+ default:
+ return FALSE;
+ }
}
/**
@@ -229,9 +266,9 @@ static void destroy(private_openssl_rsa_public_key_t *this)
{
if (this->rsa)
{
+ lib->encoding->clear_cache(lib->encoding, this->rsa);
RSA_free(this->rsa);
}
- lib->encoding->clear_cache(lib->encoding, this);
free(this);
}
}