From 00b973f8af85c3ea8fa3cef80eec55e8dc139b27 Mon Sep 17 00:00:00 2001 From: Adriaan de Jong Date: Tue, 14 Feb 2012 11:11:24 +0100 Subject: Migrated x509_get_subject to use of the garbage collector This also cleans up a messy call in pkcs11.c to _openssl_get_subject, as discussed at FOSDEM. Signed-off-by: Adriaan de Jong Acked-by: James Yonan Acked-by: David Sommerseth Signed-off-by: David Sommerseth --- src/openvpn/pkcs11_openssl.c | 16 +++++++--------- 1 file changed, 7 insertions(+), 9 deletions(-) (limited to 'src/openvpn/pkcs11_openssl.c') diff --git a/src/openvpn/pkcs11_openssl.c b/src/openvpn/pkcs11_openssl.c index 18651fd..af843b7 100644 --- a/src/openvpn/pkcs11_openssl.c +++ b/src/openvpn/pkcs11_openssl.c @@ -39,6 +39,7 @@ #include "errlevel.h" #include "pkcs11_backend.h" +#include "ssl_verify.h" #include int @@ -121,23 +122,20 @@ cleanup: return ret; } -int -pkcs11_certificate_dn (pkcs11h_certificate_t certificate, char *dn, - size_t dn_len) +char * +pkcs11_certificate_dn (pkcs11h_certificate_t certificate, struct gc_arena *gc) { X509 *x509 = NULL; - int ret = 1; + + char *dn = NULL; if ((x509 = pkcs11h_openssl_getX509 (certificate)) == NULL) { msg (M_FATAL, "PKCS#11: Cannot get X509"); - ret = 1; goto cleanup; } - _openssl_get_subject (x509, dn, dn_len); - - ret = 0; + dn = x509_get_subject (x509, gc); cleanup: if (x509 != NULL) @@ -146,7 +144,7 @@ cleanup: x509 = NULL; } - return ret; + return dn; } int -- cgit