aboutsummaryrefslogtreecommitdiffstats
path: root/src/libstrongswan/credentials/keys/signature_params.c
diff options
context:
space:
mode:
authorTobias Brunner <tobias@strongswan.org>2017-10-24 13:45:31 +0200
committerTobias Brunner <tobias@strongswan.org>2017-11-08 16:48:10 +0100
commiteae80fdedc9b71f0a5a9619110e5fa8769c3112c (patch)
tree471a93612896d8785b8de0b8553c53f1666d1190 /src/libstrongswan/credentials/keys/signature_params.c
parent6f97c0d50bad5f0d9868d4a8a91ae39c91f8cdac (diff)
downloadstrongswan-eae80fdedc9b71f0a5a9619110e5fa8769c3112c.tar.bz2
strongswan-eae80fdedc9b71f0a5a9619110e5fa8769c3112c.tar.xz
signature-params: Add helpers to parse/build ASN.1 algorithmIdentifier for signature schemes
Diffstat (limited to 'src/libstrongswan/credentials/keys/signature_params.c')
-rw-r--r--src/libstrongswan/credentials/keys/signature_params.c64
1 files changed, 64 insertions, 0 deletions
diff --git a/src/libstrongswan/credentials/keys/signature_params.c b/src/libstrongswan/credentials/keys/signature_params.c
index 79453b4ad..6b4d22e7b 100644
--- a/src/libstrongswan/credentials/keys/signature_params.c
+++ b/src/libstrongswan/credentials/keys/signature_params.c
@@ -159,6 +159,70 @@ void signature_params_clear(signature_params_t *this)
}
}
+/*
+ * Described in header
+ */
+bool signature_params_parse(chunk_t asn1, int level0,
+ signature_params_t *params)
+{
+ chunk_t parameters = chunk_empty;
+ int oid;
+
+ oid = asn1_parse_algorithmIdentifier(asn1, level0, &parameters);
+ params->scheme = signature_scheme_from_oid(oid);
+ switch (params->scheme)
+ {
+ case SIGN_UNKNOWN:
+ return FALSE;
+ case SIGN_RSA_EMSA_PSS:
+ {
+ rsa_pss_params_t *pss = malloc_thing(rsa_pss_params_t);
+
+ if (!rsa_pss_params_parse(parameters, level0+1, pss))
+ {
+ DBG1(DBG_IKE, "failed parsing RSASSA-PSS parameters");
+ free(pss);
+ return FALSE;
+ }
+ params->params = pss;
+ break;
+ }
+ default:
+ params->params = NULL;
+ break;
+ }
+ return TRUE;
+}
+
+/*
+ * Described in header
+ */
+bool signature_params_build(signature_params_t *params, chunk_t *asn1)
+{
+ chunk_t parameters = chunk_empty;
+ int oid;
+
+ oid = signature_scheme_to_oid(params->scheme);
+ if (oid == OID_UNKNOWN)
+ {
+ return FALSE;
+ }
+ if (params->scheme == SIGN_RSA_EMSA_PSS &&
+ !rsa_pss_params_build(params->params, &parameters))
+ {
+ return FALSE;
+ }
+ if (parameters.len)
+ {
+ *asn1 = asn1_algorithmIdentifier_params(oid, parameters);
+ }
+ else
+ {
+ *asn1 = asn1_algorithmIdentifier(oid);
+ }
+ return TRUE;
+}
+
/**
* ASN.1 definition of RSASSA-PSS-params
*/