blob: 065effc634c31c928a459869bca25055b0d1d993 [file] [log] [blame]
Shawn Willden0d560bf2014-12-15 17:44:02 -07001/*
2 * Copyright 2014 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef SYSTEM_KEYMASTER_HMAC_KEY_H_
18#define SYSTEM_KEYMASTER_HMAC_KEY_H_
19
20#include "symmetric_key.h"
21
22namespace keymaster {
23
Shawn Willdenf9239632015-05-12 06:57:37 -060024class HmacKeyFactory : public SymmetricKeyFactory {
25 public:
26 keymaster_algorithm_t registry_key() const override { return KM_ALGORITHM_HMAC; }
27
Shawn Willden13fbe3e2015-05-23 03:36:30 +000028 Key* LoadKey(const UnencryptedKeyBlob& blob, keymaster_error_t* error) override;
29 SymmetricKey* CreateKey(const AuthorizationSet& auths) override;
Shawn Willdenf9239632015-05-12 06:57:37 -060030};
31
Shawn Willden0d560bf2014-12-15 17:44:02 -070032class HmacKey : public SymmetricKey {
Shawn Willden13fbe3e2015-05-23 03:36:30 +000033 static const size_t MAX_HMAC_KEY_SIZE = 256; /* Arbitrary limit, for DoS prevention */
34
Shawn Willden0d560bf2014-12-15 17:44:02 -070035 public:
Shawn Willden13fbe3e2015-05-23 03:36:30 +000036 HmacKey(const AuthorizationSet& auths) : SymmetricKey(auths) {}
37 HmacKey(const UnencryptedKeyBlob& blob, keymaster_error_t* error) : SymmetricKey(blob, error) {}
38
39 private:
40 bool size_supported(size_t key_size) const override { return key_size < MAX_HMAC_KEY_SIZE; }
Shawn Willden0d560bf2014-12-15 17:44:02 -070041};
42
43} // namespace keymaster
44
45#endif // SYSTEM_KEYMASTER_HMAC_KEY_H_