| // Copyright 2023 The ChromiumOS Authors |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| |
| #ifndef LIBHWSEC_BACKEND_TPM2_ATTESTATION_H_ |
| #define LIBHWSEC_BACKEND_TPM2_ATTESTATION_H_ |
| |
| #include <string> |
| |
| #include <attestation/proto_bindings/attestation_ca.pb.h> |
| #include <attestation/proto_bindings/database.pb.h> |
| |
| #include "libhwsec/backend/attestation.h" |
| #include "libhwsec/backend/tpm2/config.h" |
| #include "libhwsec/backend/tpm2/key_management.h" |
| #include "libhwsec/backend/tpm2/random.h" |
| #include "libhwsec/backend/tpm2/signing.h" |
| #include "libhwsec/backend/tpm2/trunks_context.h" |
| #include "libhwsec/proxy/proxy.h" |
| #include "libhwsec/status.h" |
| #include "libhwsec/structures/key.h" |
| #include "libhwsec/structures/operation_policy.h" |
| |
| namespace hwsec { |
| |
| class AttestationTpm2 : public Attestation { |
| public: |
| AttestationTpm2(TrunksContext& context, |
| ConfigTpm2& config, |
| KeyManagementTpm2& key_management, |
| RandomTpm2& random, |
| SigningTpm2& signing, |
| org::chromium::TpmManagerProxyInterface& tpm_manager) |
| : context_(context), |
| config_(config), |
| key_management_(key_management), |
| random_(random), |
| signing_(signing), |
| tpm_manager_(tpm_manager) {} |
| |
| StatusOr<attestation::TpmVersion> GetTpmVersion() override; |
| StatusOr<attestation::Quote> Quote(DeviceConfigs device_configs, |
| Key key) override; |
| StatusOr<bool> IsQuoted(DeviceConfigs device_configs, |
| const attestation::Quote& quote) override; |
| StatusOr<attestation::CertifiedKey> CreateCertifiedKey( |
| Key identity_key, |
| attestation::KeyType key_type, |
| attestation::KeyUsage key_usage, |
| KeyRestriction restriction, |
| EndorsementAuth endorsement_auth, |
| const std::string& external_data) override; |
| |
| StatusOr<CreateIdentityResult> CreateIdentity( |
| attestation::KeyType key_type) override; |
| |
| StatusOr<brillo::SecureBlob> ActivateIdentity( |
| attestation::KeyType key_type, |
| Key identity_key, |
| const attestation::EncryptedIdentityCredential& encrypted_certificate) |
| override; |
| Status FinalizeEnrollmentPreparation() override; |
| |
| private: |
| // Certifies the |key| by the |identity_key| with |external_data|. |
| StatusOr<CertifyKeyResult> CertifyKey(Key key, |
| Key identity_key, |
| const std::string& external_data); |
| |
| TrunksContext& context_; |
| ConfigTpm2& config_; |
| KeyManagementTpm2& key_management_; |
| RandomTpm2& random_; |
| SigningTpm2& signing_; |
| org::chromium::TpmManagerProxyInterface& tpm_manager_; |
| }; |
| |
| } // namespace hwsec |
| |
| #endif // LIBHWSEC_BACKEND_TPM2_ATTESTATION_H_ |