| // |
| // 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 "trunks/hmac_session_impl.h" |
| |
| #include <string> |
| |
| #include <base/logging.h> |
| #include <base/macros.h> |
| #include <base/stl_util.h> |
| #include <openssl/rand.h> |
| |
| namespace trunks { |
| |
| HmacSessionImpl::HmacSessionImpl(const TrunksFactory& factory) |
| : factory_(factory) { |
| session_manager_ = factory_.GetSessionManager(); |
| } |
| |
| HmacSessionImpl::~HmacSessionImpl() { |
| session_manager_->CloseSession(); |
| } |
| |
| AuthorizationDelegate* HmacSessionImpl::GetDelegate() { |
| if (session_manager_->GetSessionHandle() == kUninitializedHandle) { |
| return nullptr; |
| } |
| return &hmac_delegate_; |
| } |
| |
| TPM_RC HmacSessionImpl::StartBoundSession( |
| TPMI_DH_ENTITY bind_entity, |
| const std::string& bind_authorization_value, |
| bool enable_encryption) { |
| return session_manager_->StartSession(TPM_SE_HMAC, bind_entity, |
| bind_authorization_value, |
| enable_encryption, &hmac_delegate_); |
| } |
| |
| TPM_RC HmacSessionImpl::StartUnboundSession(bool enable_encryption) { |
| // Starting an unbound session is the same as starting a session bound to |
| // TPM_RH_NULL. In this case, the authorization is the zero length buffer. |
| // We can therefore simply call StartBoundSession with TPM_RH_NULL as the |
| // binding entity, and the empty string as the authorization. |
| return StartBoundSession(TPM_RH_NULL, "", enable_encryption); |
| } |
| |
| void HmacSessionImpl::SetEntityAuthorizationValue(const std::string& value) { |
| hmac_delegate_.set_entity_authorization_value(value); |
| } |
| |
| void HmacSessionImpl::SetFutureAuthorizationValue(const std::string& value) { |
| hmac_delegate_.set_future_authorization_value(value); |
| } |
| |
| } // namespace trunks |