diff options
author | Martin Willi <martin@revosec.ch> | 2010-07-16 10:12:22 +0200 |
---|---|---|
committer | Martin Willi <martin@revosec.ch> | 2010-08-04 09:26:20 +0200 |
commit | 353d10d5902e5ead75ebfa701b903a8ff20660da (patch) | |
tree | b16625c56ea4c2afa471d36142952ffb61e8de02 /src/libstrongswan/plugins/openssl/openssl_rsa_private_key.c | |
parent | 5f1e4438cbce7723ad4c2afcdb01ec39bf64335c (diff) | |
download | strongswan-353d10d5902e5ead75ebfa701b903a8ff20660da.tar.bz2 strongswan-353d10d5902e5ead75ebfa701b903a8ff20660da.tar.xz |
Reuse generic passphrase build part, not a dedicated PIN part
Diffstat (limited to 'src/libstrongswan/plugins/openssl/openssl_rsa_private_key.c')
-rw-r--r-- | src/libstrongswan/plugins/openssl/openssl_rsa_private_key.c | 12 |
1 files changed, 7 insertions, 5 deletions
diff --git a/src/libstrongswan/plugins/openssl/openssl_rsa_private_key.c b/src/libstrongswan/plugins/openssl/openssl_rsa_private_key.c index b7b6e797d..d596fcf6b 100644 --- a/src/libstrongswan/plugins/openssl/openssl_rsa_private_key.c +++ b/src/libstrongswan/plugins/openssl/openssl_rsa_private_key.c @@ -451,8 +451,9 @@ openssl_rsa_private_key_t *openssl_rsa_private_key_connect(key_type_t type, { #ifndef OPENSSL_NO_ENGINE private_openssl_rsa_private_key_t *this; - char *keyid = NULL, *pin = NULL, *engine_id = NULL; - char keyname[64]; + char *keyid = NULL, *engine_id = NULL; + char keyname[64], pin[32];; + chunk_t secret = chunk_empty; EVP_PKEY *key; ENGINE *engine; int slot = -1; @@ -464,8 +465,8 @@ openssl_rsa_private_key_t *openssl_rsa_private_key_connect(key_type_t type, case BUILD_PKCS11_KEYID: keyid = va_arg(args, char*); continue; - case BUILD_PKCS11_PIN: - pin = va_arg(args, char*); + case BUILD_PASSPHRASE: + secret = va_arg(args, chunk_t); continue; case BUILD_PKCS11_SLOT: slot = va_arg(args, int); @@ -480,7 +481,7 @@ openssl_rsa_private_key_t *openssl_rsa_private_key_connect(key_type_t type, } break; } - if (!keyid || !pin) + if (!keyid || !secret.len || !secret.ptr) { return NULL; } @@ -493,6 +494,7 @@ openssl_rsa_private_key_t *openssl_rsa_private_key_connect(key_type_t type, { snprintf(keyname, sizeof(keyname), "%d:%s", slot, keyid); } + snprintf(pin, sizeof(pin), "%.*s", secret.len, secret.ptr); if (!engine_id) { |