12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364 |
- #include <keymaster/km_openssl/triple_des_key.h>
- #include <assert.h>
- #include <keymaster/new>
- #include <openssl/err.h>
- #include <openssl/rand.h>
- #include "triple_des_operation.h"
- namespace keymaster {
- static TripleDesOperationFactory encrypt_factory(KM_PURPOSE_ENCRYPT);
- static TripleDesOperationFactory decrypt_factory(KM_PURPOSE_DECRYPT);
- OperationFactory* TripleDesKeyFactory::GetOperationFactory(keymaster_purpose_t purpose) const {
- switch (purpose) {
- case KM_PURPOSE_ENCRYPT:
- return &encrypt_factory;
- case KM_PURPOSE_DECRYPT:
- return &decrypt_factory;
- default:
- return nullptr;
- }
- }
- keymaster_error_t TripleDesKeyFactory::LoadKey(KeymasterKeyBlob&& key_material,
- const AuthorizationSet& ,
- AuthorizationSet&& hw_enforced,
- AuthorizationSet&& sw_enforced,
- UniquePtr<Key>* key) const {
- if (!key) return KM_ERROR_OUTPUT_PARAMETER_NULL;
- keymaster_error_t error = KM_ERROR_OK;
- key->reset(new (std::nothrow)
- TripleDesKey(move(key_material), move(hw_enforced), move(sw_enforced), this));
- if (!key->get()) error = KM_ERROR_MEMORY_ALLOCATION_FAILED;
- return error;
- }
- keymaster_error_t TripleDesKeyFactory::validate_algorithm_specific_new_key_params(
- const AuthorizationSet& key_description) const {
- if (key_description.Contains(TAG_MIN_MAC_LENGTH)) return KM_ERROR_INVALID_TAG;
- return KM_ERROR_OK;
- }
- }
|