Android-cuttlefish cvd tool
hmac_serializable.h
Go to the documentation of this file.
1//
2// Copyright (C) 2020 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#pragma once
17
18#include <functional>
19#include <optional>
20#include <vector>
21
22#include <keymaster/serializable.h>
23
25
26namespace cuttlefish {
27
45class HmacSerializable : public keymaster::Serializable {
46public:
48 std::function<TpmObjectSlot(TpmResourceManager&)>,
49 uint32_t digest_size, Serializable*, const Serializable* aad);
50
51 size_t SerializedSize() const override;
52 uint8_t* Serialize(uint8_t* buf, const uint8_t* end) const override;
53 bool Deserialize(const uint8_t** buf_ptr, const uint8_t* end) override;
54
55private:
58 uint32_t digest_size_;
59 Serializable* wrapped_;
60 const Serializable* aad_;
61
62 std::optional<std::vector<uint8_t>> AppendAad(const uint8_t* sensitive,
63 size_t sensitive_size) const;
64};
65
66} // namespace cuttlefish
Definition: hmac_serializable.h:45
std::function< TpmObjectSlot(TpmResourceManager &)> signing_key_fn_
Definition: hmac_serializable.h:57
uint32_t digest_size_
Definition: hmac_serializable.h:58
uint8_t * Serialize(uint8_t *buf, const uint8_t *end) const override
Definition: hmac_serializable.cpp:43
size_t SerializedSize() const override
Definition: hmac_serializable.cpp:37
TpmResourceManager & resource_manager_
Definition: hmac_serializable.h:56
std::optional< std::vector< uint8_t > > AppendAad(const uint8_t *sensitive, size_t sensitive_size) const
Definition: hmac_serializable.cpp:132
const Serializable * aad_
Definition: hmac_serializable.h:60
HmacSerializable(TpmResourceManager &, std::function< TpmObjectSlot(TpmResourceManager &)>, uint32_t digest_size, Serializable *, const Serializable *aad)
Definition: hmac_serializable.cpp:27
Serializable * wrapped_
Definition: hmac_serializable.h:59
bool Deserialize(const uint8_t **buf_ptr, const uint8_t *end) override
Definition: hmac_serializable.cpp:77
Definition: tpm_resource_manager.h:50
Definition: alloc_utils.cpp:23
std::shared_ptr< TpmResourceManager::ObjectSlot > TpmObjectSlot
Definition: tpm_resource_manager.h:84