functions to retrieve certificate flags
authorDr. Stephen Henson <steve@openssl.org>
Tue, 1 Sep 2015 16:48:05 +0000 (17:48 +0100)
committerDr. Stephen Henson <steve@openssl.org>
Tue, 1 Sep 2015 19:37:45 +0000 (20:37 +0100)
Reviewed-by: Rich Salz <rsalz@openssl.org>
crypto/x509v3/v3_purp.c
include/openssl/x509v3.h

index 1f9296a930d56d68bebe0eccb318b846612983a5..13c512050b88754aeb42c3db857edd6143371deb 100644 (file)
@@ -841,3 +841,25 @@ int X509_check_akid(X509 *issuer, AUTHORITY_KEYID *akid)
     }
     return X509_V_OK;
 }
+
+uint32_t X509_get_extension_flags(X509 *x)
+{
+    X509_check_purpose(x, -1, -1);
+    return x->ex_flags;
+}
+
+uint32_t X509_get_key_usage(X509 *x)
+{
+    X509_check_purpose(x, -1, -1);
+    if (x->ex_flags & EXFLAG_KUSAGE)
+        return x->ex_kusage;
+    return UINT32_MAX;
+}
+
+uint32_t X509_get_extended_key_usage(X509 *x)
+{
+    X509_check_purpose(x, -1, -1);
+    if (x->ex_flags & EXFLAG_XKUSAGE)
+        return x->ex_xkusage;
+    return UINT32_MAX;
+}
index a46ec5d741738156a96295be03946afbd7c0061c..19fcb39883c9d6d7f6b1c97a69d9a5a3c9dc9c0d 100644 (file)
@@ -696,6 +696,11 @@ int X509_supported_extension(X509_EXTENSION *ex);
 int X509_PURPOSE_set(int *p, int purpose);
 int X509_check_issued(X509 *issuer, X509 *subject);
 int X509_check_akid(X509 *issuer, AUTHORITY_KEYID *akid);
+
+uint32_t X509_get_extension_flags(X509 *x);
+uint32_t X509_get_key_usage(X509 *x);
+uint32_t X509_get_extended_key_usage(X509 *x);
+
 int X509_PURPOSE_get_count(void);
 X509_PURPOSE *X509_PURPOSE_get0(int idx);
 int X509_PURPOSE_get_by_sname(char *sname);