Android-cuttlefish cvd tool
primary_key_builder.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 <string>
20
21#include <tss2/tss2_esys.h>
22
24
25namespace cuttlefish {
26
28public:
30
31 void SigningKey();
32 void ParentKey();
33 void UniqueData(const std::string&);
34
36
37 static TpmObjectSlot CreateSigningKey(TpmResourceManager& resource_manager,
38 const std::string& unique_data);
39
40 private:
41 TPMT_PUBLIC public_area_;
42};
43
44std::function<TpmObjectSlot(TpmResourceManager&)>
45SigningKeyCreator(const std::string& unique);
46
47std::function<TpmObjectSlot(TpmResourceManager&)>
48ParentKeyCreator(const std::string& unique);
49
50} // namespace cuttlefish
Definition: primary_key_builder.h:27
TPMT_PUBLIC public_area_
Definition: primary_key_builder.h:41
PrimaryKeyBuilder()
Definition: primary_key_builder.cpp:24
static TpmObjectSlot CreateSigningKey(TpmResourceManager &resource_manager, const std::string &unique_data)
Definition: primary_key_builder.cpp:139
void UniqueData(const std::string &)
Definition: primary_key_builder.cpp:54
void ParentKey()
Definition: primary_key_builder.cpp:39
TpmObjectSlot CreateKey(TpmResourceManager &resource_manager)
Definition: primary_key_builder.cpp:66
void SigningKey()
Definition: primary_key_builder.cpp:28
Definition: tpm_resource_manager.h:50
Definition: alloc_utils.cpp:23
std::shared_ptr< TpmResourceManager::ObjectSlot > TpmObjectSlot
Definition: tpm_resource_manager.h:84
std::function< TpmObjectSlot(TpmResourceManager &)> ParentKeyCreator(const std::string &unique)
Definition: primary_key_builder.cpp:130
std::function< TpmObjectSlot(TpmResourceManager &)> SigningKeyCreator(const std::string &unique)
Definition: primary_key_builder.cpp:120