// // Copyright (C) 2015 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // #include "tpm_manager/server/tpm2_status_impl.h" #include <base/logging.h> #include <trunks/error_codes.h> #include <trunks/tpm_generated.h> #include <trunks/trunks_factory_impl.h> using trunks::TPM_RC; using trunks::TPM_RC_SUCCESS; namespace tpm_manager { Tpm2StatusImpl::Tpm2StatusImpl(const trunks::TrunksFactory& factory) : trunks_factory_(factory), trunks_tpm_state_(trunks_factory_.GetTpmState()) {} bool Tpm2StatusImpl::IsTpmEnabled() { if (!initialized_) { Refresh(); } return trunks_tpm_state_->IsEnabled(); } bool Tpm2StatusImpl::IsTpmOwned() { if (!is_owned_) { Refresh(); } is_owned_ = trunks_tpm_state_->IsOwned(); return is_owned_; } bool Tpm2StatusImpl::GetDictionaryAttackInfo(int* counter, int* threshold, bool* lockout, int* seconds_remaining) { if (!Refresh()) { return false; } if (counter) { *counter = trunks_tpm_state_->GetLockoutCounter(); } if (threshold) { *threshold = trunks_tpm_state_->GetLockoutThreshold(); } if (lockout) { *lockout = trunks_tpm_state_->IsInLockout(); } if (seconds_remaining) { *seconds_remaining = trunks_tpm_state_->GetLockoutCounter() * trunks_tpm_state_->GetLockoutInterval(); } return true; } bool Tpm2StatusImpl::Refresh() { TPM_RC result = trunks_tpm_state_->Initialize(); if (result != TPM_RC_SUCCESS) { LOG(WARNING) << "Error initializing trunks tpm state: " << trunks::GetErrorString(result); return false; } initialized_ = true; return true; } } // namespace tpm_manager