32 return TPM2::PublicKey::generate_another(rng);
35 std::vector<uint8_t>
raw_public_key_bits()
const override {
return TPM2::PublicKey::raw_public_key_bits(); }
39 return op == PublicKeyOperation::Encryption || op == PublicKeyOperation::Signature;
42 std::unique_ptr<PK_Ops::Verification> create_verification_op(std::string_view params,
43 std::string_view provider)
const override;
46 std::string_view params,
47 std::string_view provider)
const override;
88 static std::unique_ptr<TPM2::PrivateKey> create_unrestricted_transient(
const std::shared_ptr<Context>& ctx,
90 std::span<const uint8_t> auth_value,
93 std::optional<uint32_t> exponent = {});
96 std::unique_ptr<Public_Key>
public_key()
const override {
97 return std::make_unique<Botan::RSA_PublicKey>(algorithm_identifier(), public_key_bits());
100 std::vector<uint8_t>
raw_public_key_bits()
const override {
return TPM2::PrivateKey::raw_public_key_bits(); }
104 return op == PublicKeyOperation::Encryption || op == PublicKeyOperation::Signature;
108 std::string_view params,
109 std::string_view provider)
const override;
112 std::string_view params,
113 std::string_view provider)
const override;
120 const TPM2B_PUBLIC* public_blob,
121 std::span<const uint8_t> private_blob = {});
132 const std::pair<BigInt, BigInt>& pubkey,
133 std::span<const uint8_t> private_blob = {});