Botan
1.11.15
|
#include <gost_3410.h>
GOST-34.10 Private Key
Definition at line 69 of file gost_3410.h.
Botan::GOST_3410_PrivateKey::GOST_3410_PrivateKey | ( | const AlgorithmIdentifier & | alg_id, |
const secure_vector< byte > & | key_bits | ||
) | [inline] |
Definition at line 74 of file gost_3410.h.
: EC_PrivateKey(alg_id, key_bits) {}
Botan::GOST_3410_PrivateKey::GOST_3410_PrivateKey | ( | RandomNumberGenerator & | rng, |
const EC_Group & | domain, | ||
const BigInt & | x = 0 |
||
) | [inline] |
Generate a new private key
rng | a random number generator |
domain | parameters to used for this key |
x | the private key; if zero, a new random key is generated |
Definition at line 84 of file gost_3410.h.
: EC_PrivateKey(rng, domain, x) {}
std::string Botan::GOST_3410_PublicKey::algo_name | ( | ) | const [inline, virtual, inherited] |
Get this keys algorithm name.
Implements Botan::Public_Key.
Definition at line 43 of file gost_3410.h.
{ return "GOST-34.10"; }
AlgorithmIdentifier Botan::GOST_3410_PublicKey::algorithm_identifier | ( | ) | const [virtual, inherited] |
Reimplemented from Botan::EC_PublicKey.
Definition at line 40 of file gost_3410.cpp.
References Botan::EC_PublicKey::domain(), Botan::DER_Encoder::encode(), Botan::DER_Encoder::end_cons(), Botan::DER_Encoder::get_contents_unlocked(), Botan::Public_Key::get_oid(), Botan::SEQUENCE, and Botan::DER_Encoder::start_cons().
bool Botan::EC_PublicKey::check_key | ( | RandomNumberGenerator & | rng, |
bool | strong | ||
) | const [virtual, inherited] |
Test the key values for consistency.
rng | rng to use |
strong | whether to perform strong and lengthy version of the test |
Implements Botan::Public_Key.
Reimplemented in Botan::ECDSA_PrivateKey.
Definition at line 44 of file ecc_key.cpp.
References Botan::PointGFp::on_the_curve(), and Botan::EC_PublicKey::public_point().
{ return public_point().on_the_curve(); }
std::vector<byte> Botan::EC_PublicKey::DER_domain | ( | ) | const [inline, inherited] |
Return the DER encoding of this keys domain in whatever format is preset for this particular key
Definition at line 72 of file ecc_key.h.
Referenced by Botan::EC_PublicKey::algorithm_identifier().
{ return domain().DER_encode(domain_format()); }
const EC_Group& Botan::EC_PublicKey::domain | ( | ) | const [inline, inherited] |
Get the domain parameters of this key.
Invalid_State | is thrown if the domain parameters of this point are not set |
Definition at line 60 of file ecc_key.h.
Referenced by Botan::GOST_3410_PublicKey::algorithm_identifier(), Botan::EC_PrivateKey::EC_PrivateKey(), Botan::EC_PublicKey::EC_PublicKey(), Botan::EC_PublicKey::estimated_strength(), and Botan::GOST_3410_PublicKey::GOST_3410_PublicKey().
{ return domain_params; }
EC_Group_Encoding Botan::EC_PublicKey::domain_format | ( | ) | const [inline, inherited] |
Get the domain parameter encoding to be used when encoding this key.
Definition at line 79 of file ecc_key.h.
{ return domain_encoding; }
size_t Botan::EC_PublicKey::estimated_strength | ( | ) | const [override, virtual, inherited] |
Return the estimated strength of the underlying key against the best currently known attack. Note that this ignores anything but pure attacks against the key itself and do not take into account padding schemes, usage mistakes, etc which might reduce the strength. However it does suffice to provide an upper bound.
Implements Botan::Public_Key.
Definition at line 21 of file ecc_key.cpp.
References Botan::EC_PublicKey::domain(), and Botan::ecp_work_factor().
{ return ecp_work_factor(domain().get_curve().get_p().bits()); }
void Botan::Private_Key::gen_check | ( | RandomNumberGenerator & | rng | ) | const [protected, inherited] |
Self-test after generating a key
rng | a random number generator |
Definition at line 49 of file pk_keys.cpp.
References Botan::Public_Key::algo_name(), and Botan::Public_Key::check_key().
Referenced by Botan::DH_PrivateKey::DH_PrivateKey(), Botan::DSA_PrivateKey::DSA_PrivateKey(), Botan::ElGamal_PrivateKey::ElGamal_PrivateKey(), Botan::NR_PrivateKey::NR_PrivateKey(), Botan::RSA_PrivateKey::RSA_PrivateKey(), and Botan::RW_PrivateKey::RW_PrivateKey().
OID Botan::Public_Key::get_oid | ( | ) | const [virtual, inherited] |
Get the OID of the underlying public key scheme.
Definition at line 17 of file pk_keys.cpp.
References Botan::Public_Key::algo_name(), and Botan::OIDS::lookup().
Referenced by Botan::DL_Scheme_PublicKey::algorithm_identifier(), Botan::Curve25519_PublicKey::algorithm_identifier(), Botan::IF_Scheme_PublicKey::algorithm_identifier(), Botan::GOST_3410_PublicKey::algorithm_identifier(), Botan::EC_PublicKey::algorithm_identifier(), and Botan::McEliece_PublicKey::algorithm_identifier().
{ try { return OIDS::lookup(algo_name()); } catch(Lookup_Error) { throw Lookup_Error("PK algo " + algo_name() + " has no defined OIDs"); } }
void Botan::Public_Key::load_check | ( | RandomNumberGenerator & | rng | ) | const [protected, virtual, inherited] |
Self-test after loading a key
rng | a random number generator |
Reimplemented in Botan::Private_Key.
Definition at line 31 of file pk_keys.cpp.
References Botan::Public_Key::algo_name(), and Botan::Public_Key::check_key().
{ if(!check_key(rng, BOTAN_PUBLIC_KEY_STRONG_CHECKS_ON_LOAD)) throw Invalid_Argument(algo_name() + ": Invalid public key"); }
void Botan::Private_Key::load_check | ( | RandomNumberGenerator & | rng | ) | const [protected, virtual, inherited] |
Self-test after loading a key
rng | a random number generator |
Reimplemented from Botan::Public_Key.
Definition at line 40 of file pk_keys.cpp.
References Botan::Public_Key::algo_name(), and Botan::Public_Key::check_key().
Referenced by Botan::Curve25519_PrivateKey::Curve25519_PrivateKey(), Botan::DH_PrivateKey::DH_PrivateKey(), Botan::DSA_PrivateKey::DSA_PrivateKey(), Botan::ElGamal_PrivateKey::ElGamal_PrivateKey(), Botan::IF_Scheme_PrivateKey::IF_Scheme_PrivateKey(), and Botan::NR_PrivateKey::NR_PrivateKey().
{ if(!check_key(rng, BOTAN_PRIVATE_KEY_STRONG_CHECKS_ON_LOAD)) throw Invalid_Argument(algo_name() + ": Invalid private key"); }
size_t Botan::GOST_3410_PublicKey::max_input_bits | ( | ) | const [inline, virtual, inherited] |
Get the maximum number of bits allowed to be fed to this key. This is the bitlength of the order of the base point.
Implements Botan::Public_Key.
Definition at line 55 of file gost_3410.h.
size_t Botan::GOST_3410_PublicKey::message_part_size | ( | ) | const [inline, virtual, inherited] |
Find out the message part size supported by this scheme/key.
Reimplemented from Botan::Public_Key.
Definition at line 59 of file gost_3410.h.
size_t Botan::GOST_3410_PublicKey::message_parts | ( | ) | const [inline, virtual, inherited] |
Find out the number of message parts supported by this scheme.
Reimplemented from Botan::Public_Key.
Definition at line 57 of file gost_3410.h.
{ return 2; }
AlgorithmIdentifier Botan::GOST_3410_PrivateKey::pkcs8_algorithm_identifier | ( | ) | const [inline, virtual] |
Reimplemented from Botan::Private_Key.
Definition at line 89 of file gost_3410.h.
References Botan::EC_PublicKey::algorithm_identifier().
{ return EC_PublicKey::algorithm_identifier(); }
secure_vector< byte > Botan::EC_PrivateKey::pkcs8_private_key | ( | ) | const [virtual, inherited] |
Implements Botan::Private_Key.
Definition at line 104 of file ecc_key.cpp.
References Botan::BigInt::bytes(), Botan::DER_Encoder::encode(), Botan::BigInt::encode_1363(), Botan::DER_Encoder::end_cons(), Botan::DER_Encoder::get_contents(), Botan::OCTET_STRING, Botan::EC_PrivateKey::private_key, Botan::SEQUENCE, and Botan::DER_Encoder::start_cons().
{ return DER_Encoder() .start_cons(SEQUENCE) .encode(static_cast<size_t>(1)) .encode(BigInt::encode_1363(private_key, private_key.bytes()), OCTET_STRING) .end_cons() .get_contents(); }
const BigInt & Botan::EC_PrivateKey::private_value | ( | ) | const [inherited] |
Get the private key value of this key object.
Definition at line 75 of file ecc_key.cpp.
References Botan::EC_PrivateKey::private_key.
{ if(private_key == 0) throw Invalid_State("EC_PrivateKey::private_value - uninitialized"); return private_key; }
const PointGFp& Botan::EC_PublicKey::public_point | ( | ) | const [inline, inherited] |
Get the public point of this key.
Invalid_State | is thrown if the domain parameters of this point are not set |
Definition at line 45 of file ecc_key.h.
Referenced by Botan::EC_PublicKey::check_key(), Botan::ECDSA_PrivateKey::check_key(), Botan::EC_PublicKey::EC_PublicKey(), Botan::GOST_3410_PublicKey::x509_subject_public_key(), and Botan::EC_PublicKey::x509_subject_public_key().
{ return public_key; }
void Botan::EC_PublicKey::set_parameter_encoding | ( | EC_Group_Encoding | enc | ) | [inherited] |
Set the domain parameter encoding to be used when encoding this key.
enc | the encoding to use |
Definition at line 60 of file ecc_key.cpp.
References Botan::EC_PublicKey::domain_encoding, Botan::EC_PublicKey::domain_params, Botan::EC_DOMPAR_ENC_EXPLICIT, Botan::EC_DOMPAR_ENC_IMPLICITCA, Botan::EC_DOMPAR_ENC_OID, and Botan::EC_Group::get_oid().
Referenced by Botan::DE_EAC::create_cvc_req(), Botan::DE_EAC::link_cvca(), and Botan::DE_EAC::sign_request().
{ if(form != EC_DOMPAR_ENC_EXPLICIT && form != EC_DOMPAR_ENC_IMPLICITCA && form != EC_DOMPAR_ENC_OID) throw Invalid_Argument("Invalid encoding form for EC-key object specified"); if((form == EC_DOMPAR_ENC_OID) && (domain_params.get_oid() == "")) throw Invalid_Argument("Invalid encoding form OID specified for " "EC-key object whose corresponding domain " "parameters are without oid"); domain_encoding = form; }
std::vector< byte > Botan::GOST_3410_PublicKey::x509_subject_public_key | ( | ) | const [virtual, inherited] |
Reimplemented from Botan::EC_PublicKey.
Definition at line 17 of file gost_3410.cpp.
References Botan::BigInt::binary_encode(), Botan::BigInt::bytes(), Botan::DER_Encoder::encode(), Botan::PointGFp::get_affine_x(), Botan::PointGFp::get_affine_y(), Botan::DER_Encoder::get_contents_unlocked(), Botan::OCTET_STRING, Botan::EC_PublicKey::public_point(), x, and y.
{ // Trust CryptoPro to come up with something obnoxious const BigInt x = public_point().get_affine_x(); const BigInt y = public_point().get_affine_y(); size_t part_size = std::max(x.bytes(), y.bytes()); std::vector<byte> bits(2*part_size); x.binary_encode(&bits[part_size - x.bytes()]); y.binary_encode(&bits[2*part_size - y.bytes()]); // Keys are stored in little endian format (WTF) for(size_t i = 0; i != part_size / 2; ++i) { std::swap(bits[i], bits[part_size-1-i]); std::swap(bits[part_size+i], bits[2*part_size-1-i]); } return DER_Encoder().encode(bits, OCTET_STRING).get_contents_unlocked(); }
EC_Group_Encoding Botan::EC_PublicKey::domain_encoding [protected, inherited] |
Definition at line 89 of file ecc_key.h.
Referenced by Botan::EC_PrivateKey::EC_PrivateKey(), Botan::EC_PublicKey::EC_PublicKey(), and Botan::EC_PublicKey::set_parameter_encoding().
EC_Group Botan::EC_PublicKey::domain_params [protected, inherited] |
Definition at line 87 of file ecc_key.h.
Referenced by Botan::EC_PrivateKey::EC_PrivateKey(), Botan::EC_PublicKey::EC_PublicKey(), Botan::GOST_3410_PublicKey::GOST_3410_PublicKey(), and Botan::EC_PublicKey::set_parameter_encoding().
BigInt Botan::EC_PrivateKey::private_key [protected, inherited] |
Definition at line 116 of file ecc_key.h.
Referenced by Botan::EC_PrivateKey::EC_PrivateKey(), Botan::EC_PrivateKey::pkcs8_private_key(), and Botan::EC_PrivateKey::private_value().
PointGFp Botan::EC_PublicKey::public_key [protected, inherited] |
Definition at line 88 of file ecc_key.h.
Referenced by Botan::EC_PrivateKey::EC_PrivateKey(), Botan::EC_PublicKey::EC_PublicKey(), and Botan::GOST_3410_PublicKey::GOST_3410_PublicKey().