1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071 |
- /*
- * Copyright 2014 The Android Open Source Project
- *
- * Licensed under the Apache License, Version 2.0 (the "License");
- * you may not use this file except in compliance with the License.
- * You may obtain a copy of the License at
- *
- * http://www.apache.org/licenses/LICENSE-2.0
- *
- * Unless required by applicable law or agreed to in writing, software
- * distributed under the License is distributed on an "AS IS" BASIS,
- * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
- * See the License for the specific language governing permissions and
- * limitations under the License.
- */
- #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:
- /* Don't care */
- break;
- case KM_PURPOSE_DERIVE_KEY:
- return false;
- };
- return true;
- }
- } // namespace keymaster
|