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
|
// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "crypto/unexportable_key.h"
#include "base/check.h"
#include "base/functional/bind.h"
namespace crypto {
namespace {
std::unique_ptr<UnexportableKeyProvider> (*g_mock_provider)() = nullptr;
} // namespace
UnexportableSigningKey::~UnexportableSigningKey() = default;
UnexportableKeyProvider::~UnexportableKeyProvider() = default;
VirtualUnexportableSigningKey::~VirtualUnexportableSigningKey() = default;
VirtualUnexportableKeyProvider::~VirtualUnexportableKeyProvider() = default;
bool UnexportableSigningKey::IsHardwareBacked() const {
return false;
}
#if BUILDFLAG(IS_WIN)
std::unique_ptr<UnexportableKeyProvider> GetUnexportableKeyProviderWin();
std::unique_ptr<UnexportableKeyProvider>
GetMicrosoftSoftwareUnexportableKeyProviderWin();
std::unique_ptr<VirtualUnexportableKeyProvider>
GetVirtualUnexportableKeyProviderWin();
#elif BUILDFLAG(IS_MAC)
std::unique_ptr<UnexportableKeyProvider> GetUnexportableKeyProviderMac(
UnexportableKeyProvider::Config config);
#endif
// Implemented in unexportable_key_software_unsecure.cc.
std::unique_ptr<UnexportableKeyProvider>
GetUnexportableKeyProviderSoftwareUnsecure();
std::unique_ptr<UnexportableKeyProvider> GetUnexportableKeyProvider(
UnexportableKeyProvider::Config config) {
if (g_mock_provider) {
return g_mock_provider();
}
#if BUILDFLAG(IS_WIN)
return GetUnexportableKeyProviderWin();
#elif BUILDFLAG(IS_MAC)
return GetUnexportableKeyProviderMac(std::move(config));
#else
return nullptr;
#endif
}
std::unique_ptr<UnexportableKeyProvider>
GetMicrosoftSoftwareUnexportableKeyProvider() {
if (g_mock_provider) {
return g_mock_provider();
}
#if BUILDFLAG(IS_WIN)
return GetMicrosoftSoftwareUnexportableKeyProviderWin();
#else
return nullptr;
#endif
}
std::unique_ptr<VirtualUnexportableKeyProvider>
GetVirtualUnexportableKeyProvider_DO_NOT_USE_METRICS_ONLY() {
#if BUILDFLAG(IS_WIN)
return GetVirtualUnexportableKeyProviderWin();
#else
return nullptr;
#endif
}
namespace internal {
bool HasScopedUnexportableKeyProvider() {
return g_mock_provider != nullptr;
}
void SetUnexportableKeyProviderForTesting(
std::unique_ptr<UnexportableKeyProvider> (*func)()) {
if (g_mock_provider) {
// Nesting ScopedMockUnexportableSigningKeyForTesting is not supported.
CHECK(!func);
g_mock_provider = nullptr;
} else {
g_mock_provider = func;
}
}
} // namespace internal
} // namespace crypto
|