2020-08-17 03:25:08 +08:00
|
|
|
/*
|
2023-09-07 16:59:15 +08:00
|
|
|
* Copyright 2020-2023 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
|
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),
|
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
|
|
|
|
* that it contains. The output is the same SubjectPublicKeyInfo
|
|
|
|
*/
|
|
|
|
DECODER_w_structure("DER", der, SubjectPublicKeyInfo, der, 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("DER", pem, der, yes),
|
2021-05-27 18:34:03 +08:00
|
|
|
/*
|
|
|
|
* A decoder that recognises PKCS#8 EncryptedPrivateKeyInfo structure
|
|
|
|
* and decrypts it, passing on the unencrypted PrivateKeyInfo in DER
|
|
|
|
* form to the next decoder.
|
|
|
|
*/
|
|
|
|
DECODER_w_structure("DER", der, EncryptedPrivateKeyInfo, der, yes),
|