mirror of
https://github.com/QuasarApp/openssl.git
synced 2025-05-05 05:59:38 +00:00
Renamed some values in core_names i.e Some DH specific names were changed to use DH instead of FFC. Added some strings values related to RSA keys. Moved set_params related docs out of EVP_PKEY_CTX_ctrl.pod into its own file. Updated Keyexchange and signature code and docs. Moved some common DSA/DH docs into a shared EVP_PKEY-FFC.pod. Moved Ed25519.pod into EVP_SIGNATURE-ED25519.pod and reworked it. Added some usage examples. As a result of the usage examples the following change was also made: ec allows OSSL_PKEY_PARAM_USE_COFACTOR_ECDH as a settable gen parameter. Reviewed-by: Richard Levitte <levitte@openssl.org> (Merged from https://github.com/openssl/openssl/pull/11610)
371 lines
18 KiB
C
371 lines
18 KiB
C
/*
|
|
* Copyright 2019-2020 The OpenSSL Project Authors. All Rights Reserved.
|
|
*
|
|
* Licensed under the Apache License 2.0 (the "License"). You may not use
|
|
* this file except in compliance with the License. You can obtain a copy
|
|
* in the file LICENSE in the source distribution or at
|
|
* https://www.openssl.org/source/license.html
|
|
*/
|
|
|
|
#ifndef OPENSSL_CORE_NAMES_H
|
|
# define OPENSSL_CORE_NAMES_H
|
|
|
|
# ifdef __cplusplus
|
|
extern "C" {
|
|
# endif
|
|
|
|
/* Well known parameter names that core passes to providers */
|
|
#define OSSL_PROV_PARAM_CORE_VERSION "openssl-version" /* utf8_ptr */
|
|
#define OSSL_PROV_PARAM_CORE_PROV_NAME "provider-name" /* utf8_ptr */
|
|
#define OSSL_PROV_PARAM_CORE_MODULE_FILENAME "module-filename" /* utf8_ptr */
|
|
|
|
/* Well known parameter names that Providers can define */
|
|
#define OSSL_PROV_PARAM_NAME "name" /* utf8_string */
|
|
#define OSSL_PROV_PARAM_VERSION "version" /* utf8_string */
|
|
#define OSSL_PROV_PARAM_BUILDINFO "buildinfo" /* utf8_string */
|
|
|
|
/* Self test callback parameters */
|
|
#define OSSL_PROV_PARAM_SELF_TEST_PHASE "st-phase" /* utf8_string */
|
|
#define OSSL_PROV_PARAM_SELF_TEST_TYPE "st-type" /* utf8_string */
|
|
#define OSSL_PROV_PARAM_SELF_TEST_DESC "st-desc" /* utf8_string */
|
|
|
|
/*
|
|
* Algorithm parameters
|
|
* If "engine" or "properties" are specified, they should always be paired
|
|
* with the algorithm type.
|
|
* Note these are common names that are shared by many types (such as kdf, mac,
|
|
* and pkey) e.g: see OSSL_MAC_PARAM_DIGEST below.
|
|
*/
|
|
#define OSSL_ALG_PARAM_DIGEST "digest" /* utf8_string */
|
|
#define OSSL_ALG_PARAM_CIPHER "cipher" /* utf8_string */
|
|
#define OSSL_ALG_PARAM_MAC "mac" /* utf8_string */
|
|
#define OSSL_ALG_PARAM_PROPERTIES "properties"/* utf8_string */
|
|
|
|
/* cipher parameters */
|
|
#define OSSL_CIPHER_PARAM_PADDING "padding" /* uint */
|
|
#define OSSL_CIPHER_PARAM_MODE "mode" /* uint */
|
|
#define OSSL_CIPHER_PARAM_BLOCK_SIZE "blocksize" /* size_t */
|
|
#define OSSL_CIPHER_PARAM_FLAGS "flags" /* ulong */
|
|
#define OSSL_CIPHER_PARAM_KEYLEN "keylen" /* size_t */
|
|
#define OSSL_CIPHER_PARAM_IVLEN "ivlen" /* size_t */
|
|
#define OSSL_CIPHER_PARAM_IV "iv" /* octet_string OR octet_ptr */
|
|
#define OSSL_CIPHER_PARAM_NUM "num" /* uint */
|
|
#define OSSL_CIPHER_PARAM_ROUNDS "rounds" /* uint */
|
|
#define OSSL_CIPHER_PARAM_AEAD_TAG "tag" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_AEAD_TLS1_AAD "tlsaad" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_AEAD_TLS1_AAD_PAD "tlsaadpad" /* size_t */
|
|
#define OSSL_CIPHER_PARAM_AEAD_TLS1_IV_FIXED "tlsivfixed" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_AEAD_TLS1_GET_IV_GEN "tlsivgen" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_AEAD_TLS1_SET_IV_INV "tlsivinv" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_AEAD_IVLEN OSSL_CIPHER_PARAM_IVLEN
|
|
#define OSSL_CIPHER_PARAM_AEAD_TAGLEN "taglen" /* size_t */
|
|
#define OSSL_CIPHER_PARAM_AEAD_MAC_KEY "mackey" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_RANDOM_KEY "randkey" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_RC2_KEYBITS "keybits" /* size_t */
|
|
#define OSSL_CIPHER_PARAM_SPEED "speed" /* uint */
|
|
/* For passing the AlgorithmIdentifier parameter in DER form */
|
|
#define OSSL_CIPHER_PARAM_ALG_ID "alg_id_param" /* octet_string */
|
|
|
|
#define OSSL_CIPHER_PARAM_TLS1_MULTIBLOCK_MAX_SEND_FRAGMENT \
|
|
"tls1multi_maxsndfrag" /* uint */
|
|
#define OSSL_CIPHER_PARAM_TLS1_MULTIBLOCK_MAX_BUFSIZE \
|
|
"tls1multi_maxbufsz" /* size_t */
|
|
#define OSSL_CIPHER_PARAM_TLS1_MULTIBLOCK_INTERLEAVE \
|
|
"tls1multi_interleave" /* uint */
|
|
#define OSSL_CIPHER_PARAM_TLS1_MULTIBLOCK_AAD \
|
|
"tls1multi_aad" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_TLS1_MULTIBLOCK_AAD_PACKLEN \
|
|
"tls1multi_aadpacklen" /* uint */
|
|
#define OSSL_CIPHER_PARAM_TLS1_MULTIBLOCK_ENC \
|
|
"tls1multi_enc" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_TLS1_MULTIBLOCK_ENC_IN \
|
|
"tls1multi_encin" /* octet_string */
|
|
#define OSSL_CIPHER_PARAM_TLS1_MULTIBLOCK_ENC_LEN \
|
|
"tls1multi_enclen" /* size_t */
|
|
|
|
/* digest parameters */
|
|
#define OSSL_DIGEST_PARAM_XOFLEN "xoflen" /* size_t */
|
|
#define OSSL_DIGEST_PARAM_SSL3_MS "ssl3-ms" /* octet string */
|
|
#define OSSL_DIGEST_PARAM_PAD_TYPE "pad_type" /* uint */
|
|
#define OSSL_DIGEST_PARAM_MICALG "micalg" /* utf8 string */
|
|
#define OSSL_DIGEST_PARAM_BLOCK_SIZE "blocksize" /* size_t */
|
|
#define OSSL_DIGEST_PARAM_SIZE "size" /* size_t */
|
|
#define OSSL_DIGEST_PARAM_FLAGS "flags" /* ulong */
|
|
|
|
/* Known DIGEST names (not a complete list) */
|
|
#define OSSL_DIGEST_NAME_MD5 "MD5"
|
|
#define OSSL_DIGEST_NAME_MD5_SHA1 "MD5-SHA1"
|
|
#define OSSL_DIGEST_NAME_SHA1 "SHA1"
|
|
#define OSSL_DIGEST_NAME_SHA2_224 "SHA2-224"
|
|
#define OSSL_DIGEST_NAME_SHA2_256 "SHA2-256"
|
|
#define OSSL_DIGEST_NAME_SHA2_384 "SHA2-384"
|
|
#define OSSL_DIGEST_NAME_SHA2_512 "SHA2-512"
|
|
#define OSSL_DIGEST_NAME_SHA2_512_224 "SHA2-512/224"
|
|
#define OSSL_DIGEST_NAME_SHA2_512_256 "SHA2-512/256"
|
|
#define OSSL_DIGEST_NAME_MD2 "MD2"
|
|
#define OSSL_DIGEST_NAME_MD4 "MD4"
|
|
#define OSSL_DIGEST_NAME_MDC2 "MDC2"
|
|
#define OSSL_DIGEST_NAME_RIPEMD160 "RIPEMD160"
|
|
#define OSSL_DIGEST_NAME_SHA3_224 "SHA3-224"
|
|
#define OSSL_DIGEST_NAME_SHA3_256 "SHA3-256"
|
|
#define OSSL_DIGEST_NAME_SHA3_384 "SHA3-384"
|
|
#define OSSL_DIGEST_NAME_SHA3_512 "SHA3-512"
|
|
#define OSSL_DIGEST_NAME_KECCAK_KMAC128 "KECCAK-KMAC-128"
|
|
#define OSSL_DIGEST_NAME_KECCAK_KMAC256 "KECCAK-KMAC-256"
|
|
|
|
/* MAC parameters */
|
|
#define OSSL_MAC_PARAM_KEY "key" /* octet string */
|
|
#define OSSL_MAC_PARAM_IV "iv" /* octet string */
|
|
#define OSSL_MAC_PARAM_CUSTOM "custom" /* utf8 string */
|
|
#define OSSL_MAC_PARAM_SALT "salt" /* octet string */
|
|
#define OSSL_MAC_PARAM_XOF "xof" /* int, 0 or 1 */
|
|
#define OSSL_MAC_PARAM_FLAGS "flags" /* int */
|
|
/*
|
|
* If "engine" or "properties" are specified, they should always be paired
|
|
* with "cipher" or "digest".
|
|
*/
|
|
#define OSSL_MAC_PARAM_CIPHER OSSL_ALG_PARAM_CIPHER /* utf8 string */
|
|
#define OSSL_MAC_PARAM_DIGEST OSSL_ALG_PARAM_DIGEST /* utf8 string */
|
|
#define OSSL_MAC_PARAM_PROPERTIES OSSL_ALG_PARAM_PROPERTIES /* utf8 string */
|
|
#define OSSL_MAC_PARAM_SIZE "size" /* size_t */
|
|
|
|
/* Known MAC names */
|
|
#define OSSL_MAC_NAME_BLAKE2BMAC "BLAKE2BMAC"
|
|
#define OSSL_MAC_NAME_BLAKE2SMAC "BLAKE2SMAC"
|
|
#define OSSL_MAC_NAME_CMAC "CMAC"
|
|
#define OSSL_MAC_NAME_GMAC "GMAC"
|
|
#define OSSL_MAC_NAME_HMAC "HMAC"
|
|
#define OSSL_MAC_NAME_KMAC128 "KMAC128"
|
|
#define OSSL_MAC_NAME_KMAC256 "KMAC256"
|
|
#define OSSL_MAC_NAME_POLY1305 "POLY1305"
|
|
#define OSSL_MAC_NAME_SIPHASH "SIPHASH"
|
|
|
|
/* KDF / PRF parameters */
|
|
#define OSSL_KDF_PARAM_SECRET "secret" /* octet string */
|
|
#define OSSL_KDF_PARAM_KEY "key" /* octet string */
|
|
#define OSSL_KDF_PARAM_SALT "salt" /* octet string */
|
|
#define OSSL_KDF_PARAM_PASSWORD "pass" /* octet string */
|
|
#define OSSL_KDF_PARAM_DIGEST OSSL_ALG_PARAM_DIGEST /* utf8 string */
|
|
#define OSSL_KDF_PARAM_CIPHER OSSL_ALG_PARAM_CIPHER /* utf8 string */
|
|
#define OSSL_KDF_PARAM_MAC OSSL_ALG_PARAM_MAC /* utf8 string */
|
|
#define OSSL_KDF_PARAM_MAC_SIZE "maclen" /* size_t */
|
|
#define OSSL_KDF_PARAM_PROPERTIES OSSL_ALG_PARAM_PROPERTIES /* utf8 string */
|
|
#define OSSL_KDF_PARAM_ITER "iter" /* unsigned int */
|
|
#define OSSL_KDF_PARAM_MODE "mode" /* utf8 string or int */
|
|
#define OSSL_KDF_PARAM_PKCS5 "pkcs5" /* int */
|
|
#define OSSL_KDF_PARAM_UKM "ukm" /* octet string */
|
|
#define OSSL_KDF_PARAM_CEK_ALG "cekalg" /* utf8 string */
|
|
#define OSSL_KDF_PARAM_SCRYPT_N "n" /* uint64_t */
|
|
#define OSSL_KDF_PARAM_SCRYPT_R "r" /* uint32_t */
|
|
#define OSSL_KDF_PARAM_SCRYPT_P "p" /* uint32_t */
|
|
#define OSSL_KDF_PARAM_SCRYPT_MAXMEM "maxmem_bytes" /* uint64_t */
|
|
#define OSSL_KDF_PARAM_INFO "info" /* octet string */
|
|
#define OSSL_KDF_PARAM_SEED "seed" /* octet string */
|
|
#define OSSL_KDF_PARAM_SSHKDF_XCGHASH "xcghash" /* octet string */
|
|
#define OSSL_KDF_PARAM_SSHKDF_SESSION_ID "session_id" /* octet string */
|
|
#define OSSL_KDF_PARAM_SSHKDF_TYPE "type" /* int */
|
|
#define OSSL_KDF_PARAM_SIZE "size" /* size_t */
|
|
#define OSSL_KDF_PARAM_CIPHER OSSL_ALG_PARAM_CIPHER /* utf8 string */
|
|
#define OSSL_KDF_PARAM_CONSTANT "constant" /* octet string */
|
|
|
|
/* Known KDF names */
|
|
#define OSSL_KDF_NAME_HKDF "HKDF"
|
|
#define OSSL_KDF_NAME_PBKDF2 "PBKDF2"
|
|
#define OSSL_KDF_NAME_SCRYPT "SCRYPT"
|
|
#define OSSL_KDF_NAME_SSHKDF "SSHKDF"
|
|
#define OSSL_KDF_NAME_SSKDF "SSKDF"
|
|
#define OSSL_KDF_NAME_TLS1_PRF "TLS1-PRF"
|
|
#define OSSL_KDF_NAME_X942KDF "X942KDF"
|
|
#define OSSL_KDF_NAME_X963KDF "X963KDF"
|
|
#define OSSL_KDF_NAME_KBKDF "KBKDF"
|
|
#define OSSL_KDF_NAME_KRB5KDF "KRB5KDF"
|
|
|
|
/* PKEY parameters */
|
|
/* Common PKEY parameters */
|
|
#define OSSL_PKEY_PARAM_BITS "bits" /* integer */
|
|
#define OSSL_PKEY_PARAM_MAX_SIZE "max-size" /* integer */
|
|
#define OSSL_PKEY_PARAM_SECURITY_BITS "security-bits" /* integer */
|
|
#define OSSL_PKEY_PARAM_DIGEST OSSL_ALG_PARAM_DIGEST
|
|
#define OSSL_PKEY_PARAM_PROPERTIES OSSL_ALG_PARAM_PROPERTIES
|
|
#define OSSL_PKEY_PARAM_DEFAULT_DIGEST "default-digest" /* utf8 string */
|
|
#define OSSL_PKEY_PARAM_MANDATORY_DIGEST "mandatory-digest" /* utf8 string */
|
|
#define OSSL_PKEY_PARAM_PAD_MODE "pad-mode"
|
|
#define OSSL_PKEY_PARAM_DIGEST_SIZE "digest-size"
|
|
#define OSSL_PKEY_PARAM_MASKGENFUNC "mgf"
|
|
#define OSSL_PKEY_PARAM_MGF1_DIGEST "mgf1-digest"
|
|
#define OSSL_PKEY_PARAM_MGF1_PROPERTIES "mgf1-properties"
|
|
|
|
/* Diffie-Hellman/DSA public/private key */
|
|
#define OSSL_PKEY_PARAM_PUB_KEY "pub"
|
|
#define OSSL_PKEY_PARAM_PRIV_KEY "priv"
|
|
|
|
/* Diffie-Hellman/DSA Parameters */
|
|
#define OSSL_PKEY_PARAM_FFC_P "p"
|
|
#define OSSL_PKEY_PARAM_FFC_G "g"
|
|
#define OSSL_PKEY_PARAM_FFC_Q "q"
|
|
#define OSSL_PKEY_PARAM_FFC_GINDEX "gindex"
|
|
#define OSSL_PKEY_PARAM_FFC_PCOUNTER "pcounter"
|
|
#define OSSL_PKEY_PARAM_FFC_SEED "seed"
|
|
#define OSSL_PKEY_PARAM_FFC_COFACTOR "j"
|
|
#define OSSL_PKEY_PARAM_FFC_H "hindex"
|
|
|
|
/* Diffie-Hellman params */
|
|
#define OSSL_PKEY_PARAM_DH_GROUP "group"
|
|
#define OSSL_PKEY_PARAM_DH_GENERATOR "safeprime-generator"
|
|
#define OSSL_PKEY_PARAM_DH_PRIV_LEN "priv_len"
|
|
|
|
/* Elliptic Curve Domain Parameters */
|
|
#define OSSL_PKEY_PARAM_EC_NAME "curve-name"
|
|
|
|
/* Elliptic Curve Key Parameters */
|
|
#define OSSL_PKEY_PARAM_USE_COFACTOR_FLAG "use-cofactor-flag"
|
|
#define OSSL_PKEY_PARAM_USE_COFACTOR_ECDH \
|
|
OSSL_PKEY_PARAM_USE_COFACTOR_FLAG
|
|
|
|
/* RSA Keys */
|
|
/*
|
|
* n, e, d are the usual public and private key components
|
|
*
|
|
* rsa-num is the number of factors, including p and q
|
|
* rsa-factor is used for each factor: p, q, r_i (i = 3, ...)
|
|
* rsa-exponent is used for each exponent: dP, dQ, d_i (i = 3, ...)
|
|
* rsa-coefficient is used for each coefficient: qInv, t_i (i = 3, ...)
|
|
*
|
|
* The number of rsa-factor items must be equal to the number of rsa-exponent
|
|
* items, and the number of rsa-coefficients must be one less.
|
|
* (the base i for the coefficients is 2, not 1, at least as implied by
|
|
* RFC 8017)
|
|
*/
|
|
#define OSSL_PKEY_PARAM_RSA_N "n"
|
|
#define OSSL_PKEY_PARAM_RSA_E "e"
|
|
#define OSSL_PKEY_PARAM_RSA_D "d"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR "rsa-factor"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT "rsa-exponent"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT "rsa-coefficient"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR1 OSSL_PKEY_PARAM_RSA_FACTOR"1"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR2 OSSL_PKEY_PARAM_RSA_FACTOR"2"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR3 OSSL_PKEY_PARAM_RSA_FACTOR"3"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR4 OSSL_PKEY_PARAM_RSA_FACTOR"4"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR5 OSSL_PKEY_PARAM_RSA_FACTOR"5"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR6 OSSL_PKEY_PARAM_RSA_FACTOR"6"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR7 OSSL_PKEY_PARAM_RSA_FACTOR"7"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR8 OSSL_PKEY_PARAM_RSA_FACTOR"8"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR9 OSSL_PKEY_PARAM_RSA_FACTOR"9"
|
|
#define OSSL_PKEY_PARAM_RSA_FACTOR10 OSSL_PKEY_PARAM_RSA_FACTOR"10"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT1 OSSL_PKEY_PARAM_RSA_EXPONENT"1"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT2 OSSL_PKEY_PARAM_RSA_EXPONENT"2"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT3 OSSL_PKEY_PARAM_RSA_EXPONENT"3"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT4 OSSL_PKEY_PARAM_RSA_EXPONENT"4"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT5 OSSL_PKEY_PARAM_RSA_EXPONENT"5"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT6 OSSL_PKEY_PARAM_RSA_EXPONENT"6"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT7 OSSL_PKEY_PARAM_RSA_EXPONENT"7"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT8 OSSL_PKEY_PARAM_RSA_EXPONENT"8"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT9 OSSL_PKEY_PARAM_RSA_EXPONENT"9"
|
|
#define OSSL_PKEY_PARAM_RSA_EXPONENT10 OSSL_PKEY_PARAM_RSA_EXPONENT"10"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT1 OSSL_PKEY_PARAM_RSA_COEFFICIENT"1"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT2 OSSL_PKEY_PARAM_RSA_COEFFICIENT"2"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT3 OSSL_PKEY_PARAM_RSA_COEFFICIENT"3"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT4 OSSL_PKEY_PARAM_RSA_COEFFICIENT"4"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT5 OSSL_PKEY_PARAM_RSA_COEFFICIENT"5"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT6 OSSL_PKEY_PARAM_RSA_COEFFICIENT"6"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT7 OSSL_PKEY_PARAM_RSA_COEFFICIENT"7"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT8 OSSL_PKEY_PARAM_RSA_COEFFICIENT"8"
|
|
#define OSSL_PKEY_PARAM_RSA_COEFFICIENT9 OSSL_PKEY_PARAM_RSA_COEFFICIENT"9"
|
|
|
|
/* RSA padding modes */
|
|
#define OSSL_PKEY_RSA_PAD_MODE_NONE "none"
|
|
#define OSSL_PKEY_RSA_PAD_MODE_PKCSV15 "pkcs1"
|
|
#define OSSL_PKEY_RSA_PAD_MODE_SSLV23 "sslv23"
|
|
#define OSSL_PKEY_RSA_PAD_MODE_OAEP "oaep"
|
|
#define OSSL_PKEY_RSA_PAD_MODE_X931 "x931"
|
|
#define OSSL_PKEY_RSA_PAD_MODE_PSS "pss"
|
|
|
|
/* RSA pss padding salt length */
|
|
#define OSSL_PKEY_RSA_PSS_SALT_LEN_DIGEST "digest"
|
|
#define OSSL_PKEY_RSA_PSS_SALT_LEN_MAX "max"
|
|
#define OSSL_PKEY_RSA_PSS_SALT_LEN_AUTO "auto"
|
|
|
|
/* Key generation parameters */
|
|
#define OSSL_PKEY_PARAM_RSA_BITS OSSL_PKEY_PARAM_BITS
|
|
#define OSSL_PKEY_PARAM_RSA_PRIMES "primes"
|
|
#define OSSL_PKEY_PARAM_RSA_DIGEST OSSL_PKEY_PARAM_DIGEST
|
|
#define OSSL_PKEY_PARAM_RSA_MASKGENFUNC OSSL_PKEY_PARAM_MASKGENFUNC
|
|
#define OSSL_PKEY_PARAM_RSA_MGF1_DIGEST OSSL_PKEY_PARAM_MGF1_DIGEST
|
|
#define OSSL_PKEY_PARAM_RSA_PSS_SALTLEN "saltlen"
|
|
|
|
/* Key generation parameters */
|
|
#define OSSL_PKEY_PARAM_FFC_TYPE "type"
|
|
#define OSSL_PKEY_PARAM_FFC_PBITS "pbits"
|
|
#define OSSL_PKEY_PARAM_FFC_QBITS "qbits"
|
|
#define OSSL_PKEY_PARAM_FFC_DIGEST OSSL_PKEY_PARAM_DIGEST
|
|
#define OSSL_PKEY_PARAM_FFC_DIGEST_PROPS OSSL_PKEY_PARAM_PROPERTIES
|
|
|
|
/* Key Exchange parameters */
|
|
#define OSSL_EXCHANGE_PARAM_PAD "pad" /* uint */
|
|
#define OSSL_EXCHANGE_PARAM_EC_ECDH_COFACTOR_MODE "ecdh-cofactor-mode" /* int */
|
|
#define OSSL_EXCHANGE_PARAM_KDF_TYPE "kdf-type" /* utf8_string */
|
|
#define OSSL_EXCHANGE_PARAM_KDF_DIGEST "kdf-digest" /* utf8_string */
|
|
#define OSSL_EXCHANGE_PARAM_KDF_DIGEST_PROPS "kdf-digest-props" /* utf8_string */
|
|
#define OSSL_EXCHANGE_PARAM_KDF_OUTLEN "kdf-outlen" /* size_t */
|
|
|
|
/*
|
|
* TODO(3.0): improve this pattern
|
|
*
|
|
* Currently the sole internal user of OSSL_EXCHANGE_PARAM_KDF_UKM is
|
|
* EVP_PKEY_CTX_{set0,get0}_ecdh_kdf_ukm():
|
|
* OSSL_EXCHANGE_PARAM_KDF_UKM is handled as a octet_string on set0,
|
|
* and as an octet_ptr on get0.
|
|
*
|
|
* This pattern is borrowed from the handling of
|
|
* OSSL_ASYM_CIPHER_PARAM_OAEP_LABEL in
|
|
* EVP_PKEY_CTX_{set0,get0}_rsa_oaep_label().
|
|
*/
|
|
#define OSSL_EXCHANGE_PARAM_KDF_UKM "kdf-ukm" /* see note above */
|
|
#define OSSL_EXCHANGE_PARAM_KDF_UKM_LEN "kdf-ukm-len" /* size_t */
|
|
|
|
/* Signature parameters */
|
|
#define OSSL_SIGNATURE_PARAM_ALGORITHM_ID "algorithm-id"
|
|
#define OSSL_SIGNATURE_PARAM_PAD_MODE OSSL_PKEY_PARAM_PAD_MODE
|
|
#define OSSL_SIGNATURE_PARAM_DIGEST OSSL_PKEY_PARAM_DIGEST
|
|
#define OSSL_SIGNATURE_PARAM_PROPERTIES OSSL_PKEY_PARAM_PROPERTIES
|
|
#define OSSL_SIGNATURE_PARAM_PSS_SALTLEN "saltlen"
|
|
#define OSSL_SIGNATURE_PARAM_MGF1_DIGEST OSSL_PKEY_PARAM_MGF1_DIGEST
|
|
#define OSSL_SIGNATURE_PARAM_MGF1_PROPERTIES \
|
|
OSSL_PKEY_PARAM_MGF1_PROPERTIES
|
|
#define OSSL_SIGNATURE_PARAM_DIGEST_SIZE OSSL_PKEY_PARAM_DIGEST_SIZE
|
|
#define OSSL_SIGNATURE_PARAM_KAT "kat"
|
|
|
|
/* Asym cipher parameters */
|
|
#define OSSL_ASYM_CIPHER_PARAM_PAD_MODE OSSL_PKEY_PARAM_PAD_MODE
|
|
#define OSSL_ASYM_CIPHER_PARAM_MGF1_DIGEST \
|
|
OSSL_PKEY_PARAM_MGF1_DIGEST
|
|
#define OSSL_ASYM_CIPHER_PARAM_MGF1_DIGEST_PROPS \
|
|
OSSL_PKEY_PARAM_MGF1_PROPERTIES
|
|
#define OSSL_ASYM_CIPHER_PARAM_OAEP_DIGEST OSSL_ALG_PARAM_DIGEST
|
|
#define OSSL_ASYM_CIPHER_PARAM_OAEP_DIGEST_PROPS "digest-props"
|
|
#define OSSL_ASYM_CIPHER_PARAM_OAEP_LABEL "oaep-label"
|
|
#define OSSL_ASYM_CIPHER_PARAM_OAEP_LABEL_LEN "oaep-label-len"
|
|
#define OSSL_ASYM_CIPHER_PARAM_TLS_CLIENT_VERSION "tls-client-version"
|
|
#define OSSL_ASYM_CIPHER_PARAM_TLS_NEGOTIATED_VERSION "tls-negotiated-version"
|
|
|
|
/*
|
|
* Serializer parameters
|
|
*/
|
|
/* The passphrase may be passed as a utf8 string or an octet string */
|
|
#define OSSL_SERIALIZER_PARAM_CIPHER OSSL_ALG_PARAM_CIPHER
|
|
#define OSSL_SERIALIZER_PARAM_PROPERTIES OSSL_ALG_PARAM_PROPERTIES
|
|
#define OSSL_SERIALIZER_PARAM_PASS "passphrase"
|
|
|
|
/* Passphrase callback parameters */
|
|
#define OSSL_PASSPHRASE_PARAM_INFO "info"
|
|
|
|
/* Keygen callback parameters, from provider to libcrypto */
|
|
#define OSSL_GEN_PARAM_POTENTIAL "potential" /* integer */
|
|
#define OSSL_GEN_PARAM_ITERATION "iteration" /* integer */
|
|
|
|
# ifdef __cplusplus
|
|
}
|
|
# endif
|
|
|
|
#endif
|