blob: dcd90bb4576ed7e7e93778c2a630ea366d966b73 [file]
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CRYPTO_UNEXPORTABLE_KEY_WIN_H_
#define CRYPTO_UNEXPORTABLE_KEY_WIN_H_
#include <memory>
#include "crypto/crypto_export.h"
#include "crypto/scoped_cng_types.h"
#include "crypto/unexportable_key.h"
namespace crypto {
// Attempts to reload a CNG key's handle from the given `key`. Returns the key
// on success or an invalid handle on error.
CRYPTO_EXPORT ScopedNCryptKey
DuplicatePlatformKeyHandle(const UnexportableSigningKey& key);
// Returns an `UnexportableKeyProvider` that is backed by the Windows TPM.
std::unique_ptr<UnexportableKeyProvider> GetUnexportableKeyProviderWin();
// Returns an `UnexportableKeyProvider` that is backed by the Microsoft Software
// Key Storage Provider.
std::unique_ptr<UnexportableKeyProvider>
GetMicrosoftSoftwareUnexportableKeyProviderWin();
// Returns a `VirtualUnexportableKeyProvider` that is backed by the Windows
// Credential Guard.
std::unique_ptr<VirtualUnexportableKeyProvider>
GetVirtualUnexportableKeyProviderWin();
} // namespace crypto
#endif // CRYPTO_UNEXPORTABLE_KEY_WIN_H_