11 #include <botan/pk_keys.h> 12 #include <botan/bigint.h> 30 const std::vector<uint8_t>& key_bits);
40 std::string
algo_name()
const override {
return "RSA"; }
46 std::vector<uint8_t> public_key_bits()
const override;
58 size_t key_length()
const override;
59 size_t estimated_strength()
const override;
61 std::unique_ptr<PK_Ops::Encryption>
63 const std::string& params,
64 const std::string& provider)
const override;
66 std::unique_ptr<PK_Ops::KEM_Encryption>
68 const std::string& params,
69 const std::string& provider)
const override;
71 std::unique_ptr<PK_Ops::Verification>
72 create_verification_op(
const std::string& params,
73 const std::string& provider)
const override;
117 size_t bits,
size_t exp = 65537);
145 std::unique_ptr<PK_Ops::Decryption>
147 const std::string& params,
148 const std::string& provider)
const override;
150 std::unique_ptr<PK_Ops::KEM_Decryption>
152 const std::string& params,
153 const std::string& provider)
const override;
155 std::unique_ptr<PK_Ops::Signature>
157 const std::string& params,
158 const std::string& provider)
const override;
161 BigInt m_d, m_p, m_q, m_d1, m_d2, m_c;
int(* final)(unsigned char *, CTX *)
#define BOTAN_PUBLIC_API(maj, min)
const BigInt & get_n() const
RSA_PublicKey(const BigInt &n, const BigInt &e)
const BigInt & get_c() const
const BigInt & get_d1() const
const BigInt & get_e() const
const BigInt & get_q() const
std::string algo_name() const override
const BigInt & get_d() const
const BigInt & get_d2() const
const BigInt & get_p() const
std::vector< T, secure_allocator< T > > secure_vector