aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJack Lloyd <[email protected]>2020-12-15 07:08:00 -0500
committerJack Lloyd <[email protected]>2020-12-15 07:08:00 -0500
commit07b78b3f8d135c4d512644965e0c1599b227430d (patch)
tree12f09664ded94fb2df5bc7cb148c2df69fd21968
parent972266811936d5e32860302542bfadc1c0d3e553 (diff)
Make EC_*Key constructors protected
-rw-r--r--src/lib/pubkey/ecc_key/ecc_key.h57
1 files changed, 29 insertions, 28 deletions
diff --git a/src/lib/pubkey/ecc_key/ecc_key.h b/src/lib/pubkey/ecc_key/ecc_key.h
index ec2b5f9be..629270890 100644
--- a/src/lib/pubkey/ecc_key/ecc_key.h
+++ b/src/lib/pubkey/ecc_key/ecc_key.h
@@ -28,22 +28,6 @@ namespace Botan {
class BOTAN_PUBLIC_API(2,0) EC_PublicKey : public virtual Public_Key
{
public:
- /**
- * Create a public key.
- * @param dom_par EC domain parameters
- * @param pub_point public point on the curve
- */
- EC_PublicKey(const EC_Group& dom_par,
- const PointGFp& pub_point);
-
- /**
- * Load a public key.
- * @param alg_id the X.509 algorithm identifier
- * @param key_bits DER encoded public key bits
- */
- EC_PublicKey(const AlgorithmIdentifier& alg_id,
- const std::vector<uint8_t>& key_bits);
-
EC_PublicKey(const EC_PublicKey& other) = default;
EC_PublicKey& operator=(const EC_PublicKey& other) = default;
virtual ~EC_PublicKey() = default;
@@ -108,6 +92,22 @@ class BOTAN_PUBLIC_API(2,0) EC_PublicKey : public virtual Public_Key
size_t estimated_strength() const override;
protected:
+ /**
+ * Create a public key.
+ * @param dom_par EC domain parameters
+ * @param pub_point public point on the curve
+ */
+ EC_PublicKey(const EC_Group& dom_par,
+ const PointGFp& pub_point);
+
+ /**
+ * Load a public key.
+ * @param alg_id the X.509 algorithm identifier
+ * @param key_bits DER encoded public key bits
+ */
+ EC_PublicKey(const AlgorithmIdentifier& alg_id,
+ const std::vector<uint8_t>& key_bits);
+
EC_PublicKey() : m_domain_params{}, m_public_key{}, m_domain_encoding(EC_DOMPAR_ENC_EXPLICIT)
{}
@@ -124,6 +124,19 @@ class BOTAN_PUBLIC_API(2,0) EC_PrivateKey : public virtual EC_PublicKey,
public virtual Private_Key
{
public:
+ secure_vector<uint8_t> private_key_bits() const override;
+
+ /**
+ * Get the private key value of this key object.
+ * @result the private key value of this key object
+ */
+ const BigInt& private_value() const;
+
+ EC_PrivateKey(const EC_PrivateKey& other) = default;
+ EC_PrivateKey& operator=(const EC_PrivateKey& other) = default;
+ ~EC_PrivateKey() = default;
+
+ protected:
/*
* If x=0, creates a new private key in the domain
* using the given rng. If with_modular_inverse is set,
@@ -150,18 +163,6 @@ class BOTAN_PUBLIC_API(2,0) EC_PrivateKey : public virtual EC_PublicKey,
const secure_vector<uint8_t>& key_bits,
bool with_modular_inverse=false);
- secure_vector<uint8_t> private_key_bits() const override;
-
- /**
- * Get the private key value of this key object.
- * @result the private key value of this key object
- */
- const BigInt& private_value() const;
-
- EC_PrivateKey(const EC_PrivateKey& other) = default;
- EC_PrivateKey& operator=(const EC_PrivateKey& other) = default;
- ~EC_PrivateKey() = default;
- protected:
EC_PrivateKey() = default;
BigInt m_private_key;