| // Copyright 2016 The Chromium Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style license that can be |
| // found in the LICENSE file. |
| #ifndef COMPONENTS_OS_CRYPT_OS_CRYPT_MOCKER_LINUX_H_ |
| #define COMPONENTS_OS_CRYPT_OS_CRYPT_MOCKER_LINUX_H_ |
| #include "base/strings/string_piece.h" |
| #include "components/os_crypt/key_storage_linux.h" |
| #include "third_party/abseil-cpp/absl/types/optional.h" |
| // Holds and serves a password from memory. |
| class OSCryptMockerLinux : public KeyStorageLinux { |
| OSCryptMockerLinux() = default; |
| ~OSCryptMockerLinux() override = default; |
| // Get a pointer to the stored password. OSCryptMockerLinux owns the pointer. |
| std::string* GetKeyPtr(); |
| // Inject the mocking scheme into OSCrypt. |
| // Restore OSCrypt to its real behaviour. |
| absl::optional<std::string> GetKeyImpl() override; |
| DISALLOW_COPY_AND_ASSIGN(OSCryptMockerLinux); |
| #endif // COMPONENTS_OS_CRYPT_OS_CRYPT_MOCKER_LINUX_H_ |