1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- #include <keymaster/km_openssl/rsa_key.h>
- #include <keymaster/keymaster_context.h>
- #include <keymaster/km_openssl/openssl_err.h>
- #include <keymaster/km_openssl/openssl_utils.h>
- #include <keymaster/km_openssl/rsa_operation.h>
- namespace keymaster {
- bool RsaKey::EvpToInternal(const EVP_PKEY* pkey) {
- rsa_key_.reset(EVP_PKEY_get1_RSA(const_cast<EVP_PKEY*>(pkey)));
- return rsa_key_.get() != nullptr;
- }
- bool RsaKey::InternalToEvp(EVP_PKEY* pkey) const {
- return EVP_PKEY_set1_RSA(pkey, rsa_key_.get()) == 1;
- }
- bool RsaKey::SupportedMode(keymaster_purpose_t purpose, keymaster_padding_t padding) {
- switch (purpose) {
- case KM_PURPOSE_SIGN:
- case KM_PURPOSE_VERIFY:
- return padding == KM_PAD_NONE || padding == KM_PAD_RSA_PSS ||
- padding == KM_PAD_RSA_PKCS1_1_5_SIGN;
- case KM_PURPOSE_ENCRYPT:
- case KM_PURPOSE_DECRYPT:
- case KM_PURPOSE_WRAP:
- return padding == KM_PAD_RSA_OAEP || padding == KM_PAD_RSA_PKCS1_1_5_ENCRYPT;
- case KM_PURPOSE_DERIVE_KEY:
- return false;
- };
- return false;
- }
- bool RsaKey::SupportedMode(keymaster_purpose_t purpose, keymaster_digest_t digest) {
- switch (purpose) {
- case KM_PURPOSE_SIGN:
- case KM_PURPOSE_VERIFY:
- return digest == KM_DIGEST_NONE || digest == KM_DIGEST_SHA_2_256;
- case KM_PURPOSE_ENCRYPT:
- case KM_PURPOSE_DECRYPT:
- case KM_PURPOSE_WRAP:
-
- break;
- case KM_PURPOSE_DERIVE_KEY:
- return false;
- };
- return true;
- }
- }
|