| // Copyright 2022 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_U2F_H_ |
| #define LIBHWSEC_BACKEND_TPM2_U2F_H_ |
| |
| #include <cstdint> |
| #include <optional> |
| |
| #include <brillo/secure_blob.h> |
| |
| #include "libhwsec/backend/tpm2/trunks_context.h" |
| #include "libhwsec/backend/tpm2/vendor.h" |
| #include "libhwsec/backend/u2f.h" |
| #include "libhwsec/status.h" |
| |
| namespace hwsec { |
| |
| // U2f provide the functions related to U2F vendor commands. |
| class U2fTpm2 : public U2f { |
| public: |
| U2fTpm2(TrunksContext& context, VendorTpm2& vendor) |
| : context_(context), vendor_(vendor) {} |
| |
| StatusOr<bool> IsEnabled() override; |
| StatusOr<u2f::GenerateResult> GenerateUserPresenceOnly( |
| const brillo::Blob& app_id, |
| const brillo::SecureBlob& user_secret, |
| u2f::ConsumeMode consume_mode, |
| u2f::UserPresenceMode up_mode) override; |
| StatusOr<u2f::GenerateResult> Generate( |
| const brillo::Blob& app_id, |
| const brillo::SecureBlob& user_secret, |
| u2f::ConsumeMode consume_mode, |
| u2f::UserPresenceMode up_mode, |
| const brillo::Blob& auth_time_secret_hash) override; |
| StatusOr<u2f::Signature> SignUserPresenceOnly( |
| const brillo::Blob& app_id, |
| const brillo::SecureBlob& user_secret, |
| const brillo::Blob& hash_to_sign, |
| u2f::ConsumeMode consume_mode, |
| u2f::UserPresenceMode up_mode, |
| const brillo::Blob& key_handle) override; |
| StatusOr<u2f::Signature> Sign( |
| const brillo::Blob& app_id, |
| const brillo::SecureBlob& user_secret, |
| const std::optional<brillo::SecureBlob>& auth_time_secret, |
| const brillo::Blob& hash_to_sign, |
| u2f::ConsumeMode consume_mode, |
| u2f::UserPresenceMode up_mode, |
| const brillo::Blob& key_handle) override; |
| Status CheckUserPresenceOnly(const brillo::Blob& app_id, |
| const brillo::SecureBlob& user_secret, |
| const brillo::Blob& key_handle) override; |
| Status Check(const brillo::Blob& app_id, |
| const brillo::SecureBlob& user_secret, |
| const brillo::Blob& key_handle) override; |
| StatusOr<u2f::Signature> G2fAttest(const brillo::Blob& app_id, |
| const brillo::SecureBlob& user_secret, |
| const brillo::Blob& challenge, |
| const brillo::Blob& key_handle, |
| const brillo::Blob& public_key) override; |
| StatusOr<brillo::Blob> GetG2fAttestData( |
| const brillo::Blob& app_id, |
| const brillo::Blob& challenge, |
| const brillo::Blob& key_handle, |
| const brillo::Blob& public_key) override; |
| StatusOr<u2f::Signature> CorpAttest(const brillo::Blob& app_id, |
| const brillo::SecureBlob& user_secret, |
| const brillo::Blob& challenge, |
| const brillo::Blob& key_handle, |
| const brillo::Blob& public_key, |
| const brillo::Blob& salt) override; |
| StatusOr<u2f::Config> GetConfig() override; |
| StatusOr<u2f::FipsInfo> GetFipsInfo() override; |
| Status ActivateFips() override; |
| |
| private: |
| TrunksContext& context_; |
| VendorTpm2& vendor_; |
| |
| std::optional<bool> enabled_; |
| std::optional<u2f::FipsInfo> fips_info_; |
| }; |
| |
| } // namespace hwsec |
| |
| #endif // LIBHWSEC_BACKEND_TPM2_U2F_H_ |