Annotation of embedaddon/strongswan/src/libstrongswan/plugins/wolfssl/wolfssl_plugin.c, revision 1.1
1.1 ! misho 1: /*
! 2: * Copyright (C) 2019 Sean Parkinson, wolfSSL Inc.
! 3: *
! 4: * Permission is hereby granted, free of charge, to any person obtaining a copy
! 5: * of this software and associated documentation files (the "Software"), to deal
! 6: * in the Software without restriction, including without limitation the rights
! 7: * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
! 8: * copies of the Software, and to permit persons to whom the Software is
! 9: * furnished to do so, subject to the following conditions:
! 10: *
! 11: * The above copyright notice and this permission notice shall be included in
! 12: * all copies or substantial portions of the Software.
! 13: *
! 14: * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
! 15: * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
! 16: * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
! 17: * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
! 18: * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
! 19: * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
! 20: * THE SOFTWARE.
! 21: */
! 22:
! 23: #include <library.h>
! 24: #include <utils/debug.h>
! 25:
! 26: #include "wolfssl_common.h"
! 27: #include "wolfssl_plugin.h"
! 28: #include "wolfssl_aead.h"
! 29: #include "wolfssl_crypter.h"
! 30: #include "wolfssl_diffie_hellman.h"
! 31: #include "wolfssl_ec_diffie_hellman.h"
! 32: #include "wolfssl_ec_private_key.h"
! 33: #include "wolfssl_ec_public_key.h"
! 34: #include "wolfssl_ed_private_key.h"
! 35: #include "wolfssl_ed_public_key.h"
! 36: #include "wolfssl_hasher.h"
! 37: #include "wolfssl_hmac.h"
! 38: #include "wolfssl_rsa_private_key.h"
! 39: #include "wolfssl_rsa_public_key.h"
! 40: #include "wolfssl_rng.h"
! 41: #include "wolfssl_sha1_prf.h"
! 42: #include "wolfssl_x_diffie_hellman.h"
! 43:
! 44: #ifndef FIPS_MODE
! 45: #define FIPS_MODE 0
! 46: #endif
! 47:
! 48: typedef struct private_wolfssl_plugin_t private_wolfssl_plugin_t;
! 49:
! 50: /**
! 51: * Private data of wolfssl_plugin
! 52: */
! 53: struct private_wolfssl_plugin_t {
! 54:
! 55: /**
! 56: * Public interface
! 57: */
! 58: wolfssl_plugin_t public;
! 59: };
! 60:
! 61: METHOD(plugin_t, get_name, char*,
! 62: private_wolfssl_plugin_t *this)
! 63: {
! 64: return "wolfssl";
! 65: }
! 66:
! 67: METHOD(plugin_t, get_features, int,
! 68: private_wolfssl_plugin_t *this, plugin_feature_t *features[])
! 69: {
! 70: static plugin_feature_t f[] = {
! 71: /* crypters */
! 72: PLUGIN_REGISTER(CRYPTER, wolfssl_crypter_create),
! 73: #if !defined(NO_AES) && !defined(NO_AES_CTR)
! 74: PLUGIN_PROVIDE(CRYPTER, ENCR_AES_CTR, 16),
! 75: PLUGIN_PROVIDE(CRYPTER, ENCR_AES_CTR, 24),
! 76: PLUGIN_PROVIDE(CRYPTER, ENCR_AES_CTR, 32),
! 77: #endif
! 78: #if !defined(NO_AES) && !defined(NO_AES_CBC)
! 79: PLUGIN_PROVIDE(CRYPTER, ENCR_AES_CBC, 16),
! 80: PLUGIN_PROVIDE(CRYPTER, ENCR_AES_CBC, 24),
! 81: PLUGIN_PROVIDE(CRYPTER, ENCR_AES_CBC, 32),
! 82: #endif
! 83: #ifdef HAVE_CAMELLIA
! 84: PLUGIN_PROVIDE(CRYPTER, ENCR_CAMELLIA_CBC, 16),
! 85: PLUGIN_PROVIDE(CRYPTER, ENCR_CAMELLIA_CBC, 24),
! 86: PLUGIN_PROVIDE(CRYPTER, ENCR_CAMELLIA_CBC, 32),
! 87: #endif
! 88: #ifndef NO_DES3
! 89: PLUGIN_PROVIDE(CRYPTER, ENCR_3DES, 24),
! 90: PLUGIN_PROVIDE(CRYPTER, ENCR_DES, 8),
! 91: #ifdef WOLFSSL_DES_ECB
! 92: PLUGIN_PROVIDE(CRYPTER, ENCR_DES_ECB, 8),
! 93: #endif
! 94: #endif
! 95: PLUGIN_PROVIDE(CRYPTER, ENCR_NULL, 0),
! 96: /* hashers */
! 97: PLUGIN_REGISTER(HASHER, wolfssl_hasher_create),
! 98: #ifndef NO_MD5
! 99: PLUGIN_PROVIDE(HASHER, HASH_MD5),
! 100: #endif
! 101: #ifndef NO_SHA
! 102: PLUGIN_PROVIDE(HASHER, HASH_SHA1),
! 103: #endif
! 104: #ifdef WOLFSSL_SHA224
! 105: PLUGIN_PROVIDE(HASHER, HASH_SHA224),
! 106: #endif
! 107: #ifndef NO_SHA256
! 108: PLUGIN_PROVIDE(HASHER, HASH_SHA256),
! 109: #endif
! 110: #ifdef WOLFSSL_SHA384
! 111: PLUGIN_PROVIDE(HASHER, HASH_SHA384),
! 112: #endif
! 113: #ifdef WOLFSSL_SHA512
! 114: PLUGIN_PROVIDE(HASHER, HASH_SHA512),
! 115: #endif
! 116: #ifndef NO_SHA
! 117: /* keyed sha1 hasher (aka prf) */
! 118: PLUGIN_REGISTER(PRF, wolfssl_sha1_prf_create),
! 119: PLUGIN_PROVIDE(PRF, PRF_KEYED_SHA1),
! 120: #endif
! 121: #ifndef NO_HMAC
! 122: PLUGIN_REGISTER(PRF, wolfssl_hmac_prf_create),
! 123: #ifndef NO_MD5
! 124: PLUGIN_PROVIDE(PRF, PRF_HMAC_MD5),
! 125: #endif
! 126: #ifndef NO_SHA
! 127: PLUGIN_PROVIDE(PRF, PRF_HMAC_SHA1),
! 128: #endif
! 129: #ifndef NO_SHA256
! 130: PLUGIN_PROVIDE(PRF, PRF_HMAC_SHA2_256),
! 131: #endif
! 132: #ifdef WOLFSSL_SHA384
! 133: PLUGIN_PROVIDE(PRF, PRF_HMAC_SHA2_384),
! 134: #endif
! 135: #ifdef WOLFSSL_SHA512
! 136: PLUGIN_PROVIDE(PRF, PRF_HMAC_SHA2_512),
! 137: #endif
! 138: PLUGIN_REGISTER(SIGNER, wolfssl_hmac_signer_create),
! 139: #ifndef NO_MD5
! 140: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_MD5_96),
! 141: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_MD5_128),
! 142: #endif
! 143: #ifndef NO_SHA
! 144: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_SHA1_96),
! 145: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_SHA1_128),
! 146: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_SHA1_160),
! 147: #endif
! 148: #ifndef NO_SHA256
! 149: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_SHA2_256_128),
! 150: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_SHA2_256_256),
! 151: #endif
! 152: #ifdef WOLFSSL_SHA384
! 153: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_SHA2_384_192),
! 154: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_SHA2_384_384),
! 155: #endif
! 156: #ifdef WOLFSSL_SHA512
! 157: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_SHA2_512_256),
! 158: PLUGIN_PROVIDE(SIGNER, AUTH_HMAC_SHA2_512_512),
! 159: #endif
! 160: #endif /* NO_HMAC */
! 161: #if (!defined(NO_AES) && (defined(HAVE_AESGCM) || defined(HAVE_AESCCM))) || \
! 162: (defined(HAVE_CHACHA) && defined(HAVE_POLY1305))
! 163: PLUGIN_REGISTER(AEAD, wolfssl_aead_create),
! 164: #if !defined(NO_AES) && defined(HAVE_AESGCM)
! 165: PLUGIN_PROVIDE(AEAD, ENCR_AES_GCM_ICV16, 16),
! 166: PLUGIN_PROVIDE(AEAD, ENCR_AES_GCM_ICV16, 24),
! 167: PLUGIN_PROVIDE(AEAD, ENCR_AES_GCM_ICV16, 32),
! 168: #if WOLFSSL_MIN_AUTH_TAG_SZ <= 12
! 169: PLUGIN_PROVIDE(AEAD, ENCR_AES_GCM_ICV12, 16),
! 170: PLUGIN_PROVIDE(AEAD, ENCR_AES_GCM_ICV12, 24),
! 171: PLUGIN_PROVIDE(AEAD, ENCR_AES_GCM_ICV12, 32),
! 172: #endif
! 173: #if WOLFSSL_MIN_AUTH_TAG_SZ <= 8
! 174: PLUGIN_PROVIDE(AEAD, ENCR_AES_GCM_ICV8, 16),
! 175: PLUGIN_PROVIDE(AEAD, ENCR_AES_GCM_ICV8, 24),
! 176: PLUGIN_PROVIDE(AEAD, ENCR_AES_GCM_ICV8, 32),
! 177: #endif
! 178: #endif /* !NO_AES && HAVE_AESGCM */
! 179: #if !defined(NO_AES) && defined(HAVE_AESCCM)
! 180: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV16, 16),
! 181: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV16, 24),
! 182: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV16, 32),
! 183: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV12, 16),
! 184: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV12, 24),
! 185: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV12, 32),
! 186: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV8, 16),
! 187: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV8, 24),
! 188: PLUGIN_PROVIDE(AEAD, ENCR_AES_CCM_ICV8, 32),
! 189: #endif /* !NO_AES && HAVE_AESCCM */
! 190: #if defined(HAVE_CHACHA) && defined(HAVE_POLY1305)
! 191: PLUGIN_PROVIDE(AEAD, ENCR_CHACHA20_POLY1305, 32),
! 192: #endif /* HAVE_CHACHA && HAVE_POLY1305 */
! 193: #endif
! 194: #ifdef HAVE_ECC_DHE
! 195: /* EC DH groups */
! 196: PLUGIN_REGISTER(DH, wolfssl_ec_diffie_hellman_create),
! 197: #if !defined(NO_ECC256) || defined(HAVE_ALL_CURVES)
! 198: PLUGIN_PROVIDE(DH, ECP_256_BIT),
! 199: #endif
! 200: #if defined(HAVE_ECC384) || defined(HAVE_ALL_CURVES)
! 201: PLUGIN_PROVIDE(DH, ECP_384_BIT),
! 202: #endif
! 203: #if defined(HAVE_ECC521) || defined(HAVE_ALL_CURVES)
! 204: PLUGIN_PROVIDE(DH, ECP_521_BIT),
! 205: #endif
! 206: #if defined(HAVE_ECC224) || defined(HAVE_ALL_CURVES)
! 207: PLUGIN_PROVIDE(DH, ECP_224_BIT),
! 208: #endif
! 209: #if defined(HAVE_ECC192) || defined(HAVE_ALL_CURVES)
! 210: PLUGIN_PROVIDE(DH, ECP_192_BIT),
! 211: #endif
! 212: #ifdef HAVE_BRAINPOOL
! 213: #if !define(NO_ECC256) || defined(HAVE_ALL_CURVES)
! 214: PLUGIN_PROVIDE(DH, ECP_256_BP),
! 215: #endif
! 216: #if defined(HAVE_ECC384) || defined(HAVE_ALL_CURVES)
! 217: PLUGIN_PROVIDE(DH, ECP_384_BP),
! 218: #endif
! 219: #if defined(HAVE_ECC512) || defined(HAVE_ALL_CURVES)
! 220: PLUGIN_PROVIDE(DH, ECP_512_BP),
! 221: #endif
! 222: #if defined(HAVE_ECC224) || defined(HAVE_ALL_CURVES)
! 223: PLUGIN_PROVIDE(DH, ECP_224_BP),
! 224: #endif
! 225: #endif
! 226: #endif /* HAVE_ECC_DHE */
! 227: #ifndef NO_DH
! 228: /* MODP DH groups */
! 229: PLUGIN_REGISTER(DH, wolfssl_diffie_hellman_create),
! 230: #if !defined(USE_FAST_MATH) || FP_MAX_BITS >= (3072 * 2)
! 231: PLUGIN_PROVIDE(DH, MODP_3072_BIT),
! 232: #endif
! 233: #if !defined(USE_FAST_MATH) || FP_MAX_BITS >= (4096 * 2)
! 234: PLUGIN_PROVIDE(DH, MODP_4096_BIT),
! 235: #endif
! 236: #if !defined(USE_FAST_MATH) || FP_MAX_BITS >= (6144 * 2)
! 237: PLUGIN_PROVIDE(DH, MODP_6144_BIT),
! 238: #endif
! 239: #if !defined(USE_FAST_MATH) || FP_MAX_BITS >= (8192 * 2)
! 240: PLUGIN_PROVIDE(DH, MODP_8192_BIT),
! 241: #endif
! 242: #if !defined(USE_FAST_MATH) || FP_MAX_BITS >= (2048 * 2)
! 243: PLUGIN_PROVIDE(DH, MODP_2048_BIT),
! 244: PLUGIN_PROVIDE(DH, MODP_2048_224),
! 245: PLUGIN_PROVIDE(DH, MODP_2048_256),
! 246: #endif
! 247: #if !defined(USE_FAST_MATH) || FP_MAX_BITS >= (1536 * 2)
! 248: PLUGIN_PROVIDE(DH, MODP_1536_BIT),
! 249: #endif
! 250: #if !defined(USE_FAST_MATH) || FP_MAX_BITS >= (1024 * 2)
! 251: PLUGIN_PROVIDE(DH, MODP_1024_BIT),
! 252: PLUGIN_PROVIDE(DH, MODP_1024_160),
! 253: #endif
! 254: #if !defined(USE_FAST_MATH) || FP_MAX_BITS >= (768 * 2)
! 255: PLUGIN_PROVIDE(DH, MODP_768_BIT),
! 256: #endif
! 257: PLUGIN_PROVIDE(DH, MODP_CUSTOM),
! 258: #endif /* NO_DH */
! 259: #ifndef NO_RSA
! 260: /* RSA private/public key loading */
! 261: PLUGIN_REGISTER(PRIVKEY, wolfssl_rsa_private_key_load, TRUE),
! 262: PLUGIN_PROVIDE(PRIVKEY, KEY_RSA),
! 263: PLUGIN_PROVIDE(PRIVKEY, KEY_ANY),
! 264: PLUGIN_REGISTER(PUBKEY, wolfssl_rsa_public_key_load, TRUE),
! 265: PLUGIN_PROVIDE(PUBKEY, KEY_RSA),
! 266: #ifdef WOLFSSL_KEY_GEN
! 267: PLUGIN_REGISTER(PRIVKEY_GEN, wolfssl_rsa_private_key_gen, FALSE),
! 268: PLUGIN_PROVIDE(PRIVKEY_GEN, KEY_RSA),
! 269: #endif
! 270: /* signature/encryption schemes */
! 271: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_NULL),
! 272: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_NULL),
! 273: #ifdef WC_RSA_PSS
! 274: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PSS),
! 275: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PSS),
! 276: #endif
! 277: #ifndef NO_SHA
! 278: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA1),
! 279: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA1),
! 280: #endif
! 281: #ifdef WOLFSSL_SHA224
! 282: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA2_224),
! 283: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA2_224),
! 284: #endif
! 285: #ifndef NO_SHA256
! 286: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA2_256),
! 287: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA2_256),
! 288: #endif
! 289: #ifdef WOLFSSL_SHA384
! 290: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA2_384),
! 291: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA2_384),
! 292: #endif
! 293: #ifdef WOLFSSL_SHA512
! 294: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_SHA2_512),
! 295: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_SHA2_512),
! 296: #endif
! 297: #ifndef NO_MD5
! 298: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_RSA_EMSA_PKCS1_MD5),
! 299: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_RSA_EMSA_PKCS1_MD5),
! 300: #endif
! 301: PLUGIN_PROVIDE(PRIVKEY_DECRYPT, ENCRYPT_RSA_PKCS1),
! 302: PLUGIN_PROVIDE(PUBKEY_ENCRYPT, ENCRYPT_RSA_PKCS1),
! 303: #ifndef WC_NO_RSA_OAEP
! 304: #ifndef NO_SHA
! 305: PLUGIN_PROVIDE(PUBKEY_ENCRYPT, ENCRYPT_RSA_OAEP_SHA1),
! 306: PLUGIN_PROVIDE(PRIVKEY_DECRYPT, ENCRYPT_RSA_OAEP_SHA1),
! 307: #endif
! 308: #ifdef WOLFSSL_SHA224
! 309: PLUGIN_PROVIDE(PUBKEY_ENCRYPT, ENCRYPT_RSA_OAEP_SHA224),
! 310: PLUGIN_PROVIDE(PRIVKEY_DECRYPT, ENCRYPT_RSA_OAEP_SHA224),
! 311: #endif
! 312: #ifndef NO_SHA256
! 313: PLUGIN_PROVIDE(PUBKEY_ENCRYPT, ENCRYPT_RSA_OAEP_SHA256),
! 314: PLUGIN_PROVIDE(PRIVKEY_DECRYPT, ENCRYPT_RSA_OAEP_SHA256),
! 315: #endif
! 316: #ifdef WOLFSSL_SHA384
! 317: PLUGIN_PROVIDE(PUBKEY_ENCRYPT, ENCRYPT_RSA_OAEP_SHA384),
! 318: PLUGIN_PROVIDE(PRIVKEY_DECRYPT, ENCRYPT_RSA_OAEP_SHA384),
! 319: #endif
! 320: #ifdef WOLFSSL_SHA512
! 321: PLUGIN_PROVIDE(PUBKEY_ENCRYPT, ENCRYPT_RSA_OAEP_SHA512),
! 322: PLUGIN_PROVIDE(PRIVKEY_DECRYPT, ENCRYPT_RSA_OAEP_SHA512),
! 323: #endif
! 324: #endif /* !WC_NO_RSA_OAEP */
! 325: #endif /* !NO_RSA */
! 326: #ifdef HAVE_ECC
! 327: #ifdef HAVE_ECC_KEY_IMPORT
! 328: /* EC private/public key loading */
! 329: PLUGIN_REGISTER(PRIVKEY, wolfssl_ec_private_key_load, TRUE),
! 330: PLUGIN_PROVIDE(PRIVKEY, KEY_ECDSA),
! 331: PLUGIN_PROVIDE(PRIVKEY, KEY_ANY),
! 332: #endif
! 333: #ifdef HAVE_ECC_DHE
! 334: PLUGIN_REGISTER(PRIVKEY_GEN, wolfssl_ec_private_key_gen, FALSE),
! 335: PLUGIN_PROVIDE(PRIVKEY_GEN, KEY_ECDSA),
! 336: #endif
! 337: #ifdef HAVE_ECC_KEY_IMPORT
! 338: PLUGIN_REGISTER(PUBKEY, wolfssl_ec_public_key_load, TRUE),
! 339: PLUGIN_PROVIDE(PUBKEY, KEY_ECDSA),
! 340: #endif
! 341: #ifdef HAVE_ECC_SIGN
! 342: /* signature encryption schemes */
! 343: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_ECDSA_WITH_NULL),
! 344: #ifndef NO_SHA
! 345: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_ECDSA_WITH_SHA1_DER),
! 346: #endif
! 347: #ifndef NO_SHA256
! 348: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_ECDSA_WITH_SHA256_DER),
! 349: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_ECDSA_256),
! 350: #endif
! 351: #ifdef WOLFSSL_SHA384
! 352: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_ECDSA_WITH_SHA384_DER),
! 353: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_ECDSA_384),
! 354: #endif
! 355: #ifdef WOLFSSL_SHA512
! 356: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_ECDSA_WITH_SHA512_DER),
! 357: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_ECDSA_521),
! 358: #endif
! 359: #endif /* HAVE_ECC_SIGN */
! 360: #ifdef HAVE_ECC_VERIFY
! 361: /* signature encryption schemes */
! 362: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_ECDSA_WITH_NULL),
! 363: #ifndef NO_SHA
! 364: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_ECDSA_WITH_SHA1_DER),
! 365: #endif
! 366: #ifndef NO_SHA256
! 367: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_ECDSA_WITH_SHA256_DER),
! 368: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_ECDSA_256),
! 369: #endif
! 370: #ifdef WOLFSSL_SHA384
! 371: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_ECDSA_WITH_SHA384_DER),
! 372: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_ECDSA_384),
! 373: #endif
! 374: #ifdef WOLFSSL_SHA512
! 375: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_ECDSA_WITH_SHA512_DER),
! 376: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_ECDSA_521),
! 377: #endif
! 378: #endif /* HAVE_ECC_VERIFY */
! 379: #endif /* HAVE_ECC */
! 380: #ifdef HAVE_CURVE25519
! 381: PLUGIN_REGISTER(DH, wolfssl_x_diffie_hellman_create),
! 382: PLUGIN_PROVIDE(DH, CURVE_25519),
! 383: #endif
! 384: #ifdef HAVE_ED25519
! 385: /* EdDSA private/public key loading */
! 386: PLUGIN_REGISTER(PUBKEY, wolfssl_ed_public_key_load, TRUE),
! 387: PLUGIN_PROVIDE(PUBKEY, KEY_ED25519),
! 388: PLUGIN_REGISTER(PRIVKEY, wolfssl_ed_private_key_load, TRUE),
! 389: PLUGIN_PROVIDE(PRIVKEY, KEY_ED25519),
! 390: PLUGIN_REGISTER(PRIVKEY_GEN, wolfssl_ed_private_key_gen, FALSE),
! 391: PLUGIN_PROVIDE(PRIVKEY_GEN, KEY_ED25519),
! 392: #ifdef HAVE_ED25519_SIGN
! 393: PLUGIN_PROVIDE(PRIVKEY_SIGN, SIGN_ED25519),
! 394: #endif
! 395: #ifdef HAVE_ED25519_VERIFY
! 396: PLUGIN_PROVIDE(PUBKEY_VERIFY, SIGN_ED25519),
! 397: #endif
! 398: /* register a pro forma identity hasher, never instantiated */
! 399: PLUGIN_REGISTER(HASHER, return_null),
! 400: PLUGIN_PROVIDE(HASHER, HASH_IDENTITY),
! 401: #endif /* HAVE_ED25519 */
! 402: #ifndef WC_NO_RNG
! 403: /* generic key loader */
! 404: PLUGIN_REGISTER(RNG, wolfssl_rng_create),
! 405: PLUGIN_PROVIDE(RNG, RNG_STRONG),
! 406: PLUGIN_PROVIDE(RNG, RNG_WEAK),
! 407: #endif
! 408: };
! 409: *features = f;
! 410: return countof(f);
! 411: }
! 412:
! 413: METHOD(plugin_t, destroy, void,
! 414: private_wolfssl_plugin_t *this)
! 415: {
! 416: #ifndef WC_NO_RNG
! 417: wolfssl_rng_global_final();
! 418: #endif
! 419: wolfSSL_Cleanup();
! 420:
! 421: free(this);
! 422: }
! 423:
! 424: /*
! 425: * Described in header
! 426: */
! 427: plugin_t *wolfssl_plugin_create()
! 428: {
! 429: private_wolfssl_plugin_t *this;
! 430: bool fips_mode;
! 431:
! 432: fips_mode = lib->settings->get_bool(lib->settings,
! 433: "%s.plugins.wolfssl.fips_mode", FALSE, lib->ns);
! 434: #ifdef HAVE_FIPS
! 435: if (fips_mode)
! 436: {
! 437: int ret = wolfCrypt_GetStatus_fips();
! 438: if (ret != 0)
! 439: {
! 440: DBG1(DBG_LIB, "wolfssl FIPS mode unavailable (%d)", ret);
! 441: return NULL;
! 442: }
! 443: }
! 444: #else
! 445: if (fips_mode)
! 446: {
! 447: DBG1(DBG_LIB, "wolfssl FIPS mode unavailable");
! 448: return NULL;
! 449: }
! 450: #endif
! 451:
! 452: wolfSSL_Init();
! 453: #ifndef WC_NO_RNG
! 454: if (!wolfssl_rng_global_init())
! 455: {
! 456: return NULL;
! 457: }
! 458: #endif
! 459:
! 460: INIT(this,
! 461: .public = {
! 462: .plugin = {
! 463: .get_name = _get_name,
! 464: .get_features = _get_features,
! 465: .destroy = _destroy,
! 466: },
! 467: },
! 468: );
! 469:
! 470: return &this->public.plugin;
! 471: }
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>