// // Copyright (C) 2014 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. // #ifndef TRUNKS_SCOPED_KEY_HANDLE_H_ #define TRUNKS_SCOPED_KEY_HANDLE_H_ #include "trunks/tpm_generated.h" #include "trunks/trunks_export.h" #include "trunks/trunks_factory.h" namespace trunks { // This class is used to wrap a Key or NV ram handle given by the TPM. // It provides a destructor that cleans up TPM resources associated with // that handle. class TRUNKS_EXPORT ScopedKeyHandle { public: // We provide a factory to the constructor so that we can later free // resources associated with the handle. explicit ScopedKeyHandle(const TrunksFactory& factory); ScopedKeyHandle(const TrunksFactory& factory, TPM_HANDLE handle); virtual ~ScopedKeyHandle(); // This method releases the TPM_HANDLE associated with this class. // It returns the handle that was previously wrapped, and returns // INVALID_HANDLE if the previous handle was unset. virtual TPM_HANDLE release(); // This method flushes all context associated with the current handle, // and has the class wrap |new_handle| virtual void reset(TPM_HANDLE new_handle); // This method flushes all context associated with the current handle, // and resets the internal handle of the class to the uninitialized value. // Note: After reset() this class should not be used again till a new handle // is injected. virtual void reset(); // This method returns a pointer to the handle associated with this class. // This method does not transfer ownership. virtual TPM_HANDLE* ptr(); // This method returns the handle currectly associated with the class. // This method does not transfer ownership, therefore the handle returned // might be stale. virtual TPM_HANDLE get() const; private: const TrunksFactory& factory_; TPM_HANDLE handle_; void FlushHandleContext(TPM_HANDLE handle); DISALLOW_COPY_AND_ASSIGN(ScopedKeyHandle); }; } // namespace trunks #endif // TRUNKS_SCOPED_KEY_HANDLE_H_