2020-08-17 03:25:08 +08:00
|
|
|
/*
|
2025-03-12 21:35:59 +08:00
|
|
|
* Copyright 2020-2025 The OpenSSL Project Authors. All Rights Reserved.
|
2020-08-17 03:25:08 +08:00
|
|
|
*
|
|
|
|
* 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
|
|
|
|
*/
|
|
|
|
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
#ifndef DECODER_PROVIDER
|
|
|
|
# error Macro DECODER_PROVIDER undefined
|
2020-08-17 03:25:08 +08:00
|
|
|
#endif
|
|
|
|
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
#define DECODER_STRUCTURE_type_specific_keypair "type-specific"
|
|
|
|
#define DECODER_STRUCTURE_type_specific_params "type-specific"
|
|
|
|
#define DECODER_STRUCTURE_type_specific "type-specific"
|
|
|
|
#define DECODER_STRUCTURE_type_specific_no_pub "type-specific"
|
2021-05-27 18:34:03 +08:00
|
|
|
#define DECODER_STRUCTURE_EncryptedPrivateKeyInfo "EncryptedPrivateKeyInfo"
|
|
|
|
#define DECODER_STRUCTURE_PrivateKeyInfo "PrivateKeyInfo"
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
#define DECODER_STRUCTURE_SubjectPublicKeyInfo "SubjectPublicKeyInfo"
|
|
|
|
#define DECODER_STRUCTURE_DH "dh"
|
|
|
|
#define DECODER_STRUCTURE_DHX "dhx"
|
|
|
|
#define DECODER_STRUCTURE_DSA "dsa"
|
|
|
|
#define DECODER_STRUCTURE_EC "ec"
|
|
|
|
#define DECODER_STRUCTURE_RSA "rsa"
|
|
|
|
|
|
|
|
/* Arguments are prefixed with '_' to avoid build breaks on certain platforms */
|
|
|
|
#define DECODER(_name, _input, _output, _fips) \
|
|
|
|
{ _name, \
|
|
|
|
"provider=" DECODER_PROVIDER ",fips=" #_fips ",input=" #_input, \
|
|
|
|
(ossl_##_input##_to_##_output##_decoder_functions) }
|
|
|
|
#define DECODER_w_structure(_name, _input, _structure, _output, _fips) \
|
|
|
|
{ _name, \
|
|
|
|
"provider=" DECODER_PROVIDER ",fips=" #_fips ",input=" #_input \
|
|
|
|
",structure=" DECODER_STRUCTURE_##_structure, \
|
|
|
|
(ossl_##_structure##_##_input##_to_##_output##_decoder_functions) }
|
|
|
|
|
2020-08-17 03:25:08 +08:00
|
|
|
#ifndef OPENSSL_NO_DH
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("DH", der, PrivateKeyInfo, dh, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("DH", der, SubjectPublicKeyInfo, dh, yes),
|
|
|
|
DECODER_w_structure("DH", der, type_specific_params, dh, yes),
|
|
|
|
DECODER_w_structure("DH", der, DH, dh, yes),
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("DHX", der, PrivateKeyInfo, dhx, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("DHX", der, SubjectPublicKeyInfo, dhx, yes),
|
|
|
|
DECODER_w_structure("DHX", der, type_specific_params, dhx, yes),
|
|
|
|
DECODER_w_structure("DHX", der, DHX, dhx, yes),
|
2020-08-17 03:25:08 +08:00
|
|
|
#endif
|
|
|
|
#ifndef OPENSSL_NO_DSA
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("DSA", der, PrivateKeyInfo, dsa, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("DSA", der, SubjectPublicKeyInfo, dsa, yes),
|
|
|
|
DECODER_w_structure("DSA", der, type_specific, dsa, yes),
|
|
|
|
DECODER_w_structure("DSA", der, DSA, dsa, yes),
|
|
|
|
DECODER("DSA", msblob, dsa, yes),
|
|
|
|
DECODER("DSA", pvk, dsa, yes),
|
2020-08-17 03:25:08 +08:00
|
|
|
#endif
|
|
|
|
#ifndef OPENSSL_NO_EC
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("EC", der, PrivateKeyInfo, ec, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("EC", der, SubjectPublicKeyInfo, ec, yes),
|
|
|
|
DECODER_w_structure("EC", der, type_specific_no_pub, ec, yes),
|
|
|
|
DECODER_w_structure("EC", der, EC, ec, yes),
|
2023-04-17 16:20:31 +08:00
|
|
|
# ifndef OPENSSL_NO_ECX
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("ED25519", der, PrivateKeyInfo, ed25519, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("ED25519", der, SubjectPublicKeyInfo, ed25519, yes),
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("ED448", der, PrivateKeyInfo, ed448, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("ED448", der, SubjectPublicKeyInfo, ed448, yes),
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("X25519", der, PrivateKeyInfo, x25519, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("X25519", der, SubjectPublicKeyInfo, x25519, yes),
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("X448", der, PrivateKeyInfo, x448, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("X448", der, SubjectPublicKeyInfo, x448, yes),
|
2023-04-17 16:20:31 +08:00
|
|
|
# endif
|
2021-01-28 15:22:09 +08:00
|
|
|
# ifndef OPENSSL_NO_SM2
|
2021-06-16 06:44:28 +08:00
|
|
|
DECODER_w_structure("SM2", der, PrivateKeyInfo, sm2, no),
|
|
|
|
DECODER_w_structure("SM2", der, SubjectPublicKeyInfo, sm2, no),
|
2022-07-19 01:18:12 +08:00
|
|
|
DECODER_w_structure("SM2", der, type_specific_no_pub, sm2, no),
|
2021-01-28 15:22:09 +08:00
|
|
|
# endif
|
2020-08-17 03:25:08 +08:00
|
|
|
#endif
|
2025-01-09 11:35:03 +08:00
|
|
|
#ifndef OPENSSL_NO_ML_KEM
|
|
|
|
DECODER_w_structure("ML-KEM-512", der, PrivateKeyInfo, ml_kem_512, yes),
|
|
|
|
DECODER_w_structure("ML-KEM-512", der, SubjectPublicKeyInfo, ml_kem_512, yes),
|
|
|
|
DECODER_w_structure("ML-KEM-768", der, PrivateKeyInfo, ml_kem_768, yes),
|
|
|
|
DECODER_w_structure("ML-KEM-768", der, SubjectPublicKeyInfo, ml_kem_768, yes),
|
|
|
|
DECODER_w_structure("ML-KEM-1024", der, PrivateKeyInfo, ml_kem_1024, yes),
|
|
|
|
DECODER_w_structure("ML-KEM-1024", der, SubjectPublicKeyInfo, ml_kem_1024, yes),
|
|
|
|
#endif
|
2024-11-19 12:40:13 +08:00
|
|
|
#ifndef OPENSSL_NO_SLH_DSA
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-128s", der, PrivateKeyInfo, slh_dsa_sha2_128s, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-128f", der, PrivateKeyInfo, slh_dsa_sha2_128f, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-192s", der, PrivateKeyInfo, slh_dsa_sha2_192s, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-192f", der, PrivateKeyInfo, slh_dsa_sha2_192f, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-256s", der, PrivateKeyInfo, slh_dsa_sha2_256s, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-256f", der, PrivateKeyInfo, slh_dsa_sha2_256f, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-128s", der, PrivateKeyInfo, slh_dsa_shake_128s, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-128f", der, PrivateKeyInfo, slh_dsa_shake_128f, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-192s", der, PrivateKeyInfo, slh_dsa_shake_192s, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-192f", der, PrivateKeyInfo, slh_dsa_shake_192f, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-256s", der, PrivateKeyInfo, slh_dsa_shake_256s, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-256f", der, PrivateKeyInfo, slh_dsa_shake_256f, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-128s", der, SubjectPublicKeyInfo, slh_dsa_sha2_128s, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-128f", der, SubjectPublicKeyInfo, slh_dsa_sha2_128f, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-192s", der, SubjectPublicKeyInfo, slh_dsa_sha2_192s, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-192f", der, SubjectPublicKeyInfo, slh_dsa_sha2_192f, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-256s", der, SubjectPublicKeyInfo, slh_dsa_sha2_256s, yes),
|
|
|
|
DECODER_w_structure( "SLH-DSA-SHA2-256f", der, SubjectPublicKeyInfo, slh_dsa_sha2_256f, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-128s", der, SubjectPublicKeyInfo, slh_dsa_shake_128s, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-128f", der, SubjectPublicKeyInfo, slh_dsa_shake_128f, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-192s", der, SubjectPublicKeyInfo, slh_dsa_shake_192s, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-192f", der, SubjectPublicKeyInfo, slh_dsa_shake_192f, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-256s", der, SubjectPublicKeyInfo, slh_dsa_shake_256s, yes),
|
|
|
|
DECODER_w_structure("SLH-DSA-SHAKE-256f", der, SubjectPublicKeyInfo, slh_dsa_shake_256f, yes),
|
|
|
|
#endif /* OPENSSL_NO_SLH_DSA */
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("RSA", der, PrivateKeyInfo, rsa, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("RSA", der, SubjectPublicKeyInfo, rsa, yes),
|
|
|
|
DECODER_w_structure("RSA", der, type_specific_keypair, rsa, yes),
|
|
|
|
DECODER_w_structure("RSA", der, RSA, rsa, yes),
|
2021-05-27 18:34:03 +08:00
|
|
|
DECODER_w_structure("RSA-PSS", der, PrivateKeyInfo, rsapss, yes),
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER_w_structure("RSA-PSS", der, SubjectPublicKeyInfo, rsapss, yes),
|
|
|
|
DECODER("RSA", msblob, rsa, yes),
|
|
|
|
DECODER("RSA", pvk, rsa, yes),
|
2025-01-10 09:41:12 +08:00
|
|
|
#ifndef OPENSSL_NO_ML_DSA
|
2025-02-03 12:22:00 +08:00
|
|
|
DECODER_w_structure("ML-DSA-44", der, PrivateKeyInfo, ml_dsa_44, yes),
|
|
|
|
DECODER_w_structure("ML-DSA-65", der, PrivateKeyInfo, ml_dsa_65, yes),
|
|
|
|
DECODER_w_structure("ML-DSA-87", der, PrivateKeyInfo, ml_dsa_87, yes),
|
|
|
|
DECODER_w_structure("ML-DSA-44", der, SubjectPublicKeyInfo, ml_dsa_44, yes),
|
|
|
|
DECODER_w_structure("ML-DSA-65", der, SubjectPublicKeyInfo, ml_dsa_65, yes),
|
|
|
|
DECODER_w_structure("ML-DSA-87", der, SubjectPublicKeyInfo, ml_dsa_87, yes),
|
2025-01-10 09:41:12 +08:00
|
|
|
#endif /* OPENSSL_NO_ML_DSA */
|
2020-08-17 03:25:08 +08:00
|
|
|
|
2021-06-08 18:49:06 +08:00
|
|
|
/*
|
|
|
|
* A decoder that takes a SubjectPublicKeyInfo and figures out the types of key
|
2025-02-25 15:17:02 +08:00
|
|
|
* that it contains. The output is the same SubjectPublicKeyInfo.
|
2021-06-08 18:49:06 +08:00
|
|
|
*/
|
|
|
|
DECODER_w_structure("DER", der, SubjectPublicKeyInfo, der, yes),
|
2025-02-25 15:17:02 +08:00
|
|
|
/*
|
|
|
|
* General-purpose PEM to DER decoder. When the user-specified data structure
|
|
|
|
* is a possibly encrypted PKCS#8 PrivateKeyInfo or a SubjectPublicKeyInfo
|
|
|
|
* public key, or interest in such a key is indicated via the "selection", and
|
|
|
|
* the current object is of that type, decodes the PKCS#8 or SPKI identifying
|
|
|
|
* algorithm name or OID, and delegates further decoding in DER form to the
|
|
|
|
* identified algorithm.
|
|
|
|
*/
|
PROV: Re-implement all the keypair decoders
The base functionality to implement the keypair decoders doesn't
change much, but this results in a more massive amount of
OSSL_DISPATCH and OSSL_ALGORITHM arrays, to support a fine grained
selection of implementation based on what parts of the keypair
structure (combinations of key parameters, public key and private key)
should be expected as input, the input type ("DER", "PEM", ...) and the
outermost input structure ("pkcs8", "SubjectPublicKeyInfo", key
type specific structures, ...).
We add support for the generic structure name "type-specific", to
allow selecting that without knowing the exact name of that structure.
Reviewed-by: Shane Lontis <shane.lontis@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/13248)
2020-10-26 20:22:54 +08:00
|
|
|
DECODER("DER", pem, der, yes),
|
2021-05-27 18:34:03 +08:00
|
|
|
/*
|
2025-02-25 15:17:02 +08:00
|
|
|
* A decoder that recognises PKCS#8 EncryptedPrivateKeyInfo structure and
|
|
|
|
* decrypts it, obtaining the algorithm name or OID, and delegates the
|
|
|
|
* unencrypted PrivateKeyInfo in DER form to the identified algorithm.
|
2021-05-27 18:34:03 +08:00
|
|
|
*/
|
|
|
|
DECODER_w_structure("DER", der, EncryptedPrivateKeyInfo, der, yes),
|
2024-10-01 00:38:58 +08:00
|
|
|
|
|
|
|
#ifndef OPENSSL_NO_LMS
|
|
|
|
DECODER("LMS", xdr, lms, yes),
|
|
|
|
#endif
|