1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
|
// Copyright 2023 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef COMPONENTS_OS_CRYPT_ASYNC_BROWSER_OS_CRYPT_ASYNC_H_
#define COMPONENTS_OS_CRYPT_ASYNC_BROWSER_OS_CRYPT_ASYNC_H_
#include <list>
#include <memory>
#include <optional>
#include <vector>
#include "base/component_export.h"
#include "base/functional/callback.h"
#include "base/memory/weak_ptr.h"
#include "base/sequence_checker.h"
#include "base/types/expected.h"
#include "components/os_crypt/async/browser/key_provider.h"
#include "components/os_crypt/async/common/encryptor.h"
namespace os_crypt_async {
// This class is responsible for vending Encryptor instances.
class COMPONENT_EXPORT(OS_CRYPT_ASYNC) OSCryptAsync {
public:
using InitCallback = base::OnceCallback<void(Encryptor)>;
// Higher precedence providers will be used for encryption over lower
// preference ones.
using Precedence = size_t;
// Create an OSCryptAsync with the defined list of `providers`.
//
// Each provider consists of a pair that defines the precedence of the
// provider and the provider implementation.
//
// The provider with the highest precedence that supplies a valid Key, and
// also signals that it can be used for encryption by returning `true` from
// the `UseForEncryption` interface method will be used for encryption.
//
// If no providers are available for encryption, legacy OSCrypt will be used
// for encryption.
//
// Any provider that supplies a Key, regardless of their precedence or whether
// or not they signal `UseForEncryption`, will make that Key available for
// decryption of data that was previously encrypted with the same Key.
explicit OSCryptAsync(
std::vector<std::pair<Precedence, std::unique_ptr<KeyProvider>>>
providers);
virtual ~OSCryptAsync();
// Not moveable. Not copyable.
OSCryptAsync(OSCryptAsync&& other) = delete;
OSCryptAsync& operator=(OSCryptAsync&& other) = delete;
OSCryptAsync(const OSCryptAsync&) = delete;
OSCryptAsync& operator=(const OSCryptAsync&) = delete;
// Obtain an Encryptor instance. Can be called multiple times, each one will
// get a valid instance once the initialization has completed, on the
// `callback`. `option` determines characteristics of the resulting Encryptor
// instance returned in the callback, see encryptor.h. Must be called on the
// same sequence that the OSCryptAsync object was created on.
// The callback might be executed before this function returns, if the
// Encryptor is already available.
virtual void GetInstance(InitCallback callback, Encryptor::Option option);
// Same as the `GetInstance` method above but uses a default option.
void GetInstance(InitCallback callback);
private:
using ProviderIterator =
std::vector<std::unique_ptr<KeyProvider>>::const_iterator;
void CallbackHelper(InitCallback callback, Encryptor::Option option) const;
void HandleKey(ProviderIterator current,
const std::string& tag,
base::expected<Encryptor::Key, KeyProvider::KeyError> key);
// Sets the `encryptor_instance_` and reports metrics.
void SetEncryptorInstance(Encryptor encryptor);
std::unique_ptr<Encryptor> encryptor_instance_
GUARDED_BY_CONTEXT(sequence_checker_);
bool is_initialized_ GUARDED_BY_CONTEXT(sequence_checker_) = false;
bool is_initializing_ GUARDED_BY_CONTEXT(sequence_checker_) = false;
const std::vector<std::unique_ptr<KeyProvider>> providers_
GUARDED_BY_CONTEXT(sequence_checker_);
std::list<base::OnceClosure> callbacks_ GUARDED_BY_CONTEXT(sequence_checker_);
Encryptor::KeyRing key_ring_ GUARDED_BY_CONTEXT(sequence_checker_);
std::string provider_for_encryption_ GUARDED_BY_CONTEXT(sequence_checker_);
std::string provider_for_os_crypt_sync_compatible_encryption_
GUARDED_BY_CONTEXT(sequence_checker_);
size_t number_of_failing_key_providers_
GUARDED_BY_CONTEXT(sequence_checker_) = 0;
SEQUENCE_CHECKER(sequence_checker_);
base::WeakPtrFactory<OSCryptAsync> weak_factory_{this};
};
} // namespace os_crypt_async
#endif // COMPONENTS_OS_CRYPT_ASYNC_BROWSER_OS_CRYPT_ASYNC_H_
|