aboutsummaryrefslogtreecommitdiffstats
path: root/src/libstrongswan/plugins/openssl/openssl_rsa_private_key.c
diff options
context:
space:
mode:
authorMartin Willi <martin@revosec.ch>2010-07-16 10:12:22 +0200
committerMartin Willi <martin@revosec.ch>2010-08-04 09:26:20 +0200
commit353d10d5902e5ead75ebfa701b903a8ff20660da (patch)
treeb16625c56ea4c2afa471d36142952ffb61e8de02 /src/libstrongswan/plugins/openssl/openssl_rsa_private_key.c
parent5f1e4438cbce7723ad4c2afcdb01ec39bf64335c (diff)
downloadstrongswan-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.c12
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)
{