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
|
// Copyright 2012 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_OWNERSHIP_MOCK_OWNER_KEY_UTIL_H_
#define COMPONENTS_OWNERSHIP_MOCK_OWNER_KEY_UTIL_H_
#include <stdint.h>
#include <memory>
#include <optional>
#include <vector>
#include "base/compiler_specific.h"
#include "components/ownership/owner_key_util.h"
#include "components/ownership/ownership_export.h"
#include "crypto/keypair.h"
namespace ownership {
// Implementation of OwnerKeyUtil which should be used only for
// testing.
class OWNERSHIP_EXPORT MockOwnerKeyUtil : public OwnerKeyUtil {
public:
MockOwnerKeyUtil();
MockOwnerKeyUtil(const MockOwnerKeyUtil&) = delete;
MockOwnerKeyUtil& operator=(const MockOwnerKeyUtil&) = delete;
// OwnerKeyUtil implementation:
scoped_refptr<PublicKey> ImportPublicKey() override;
crypto::ScopedSECKEYPrivateKey GenerateKeyPair(PK11SlotInfo* slot) override;
crypto::ScopedSECKEYPrivateKey FindPrivateKeyInSlot(
const std::vector<uint8_t>& key,
PK11SlotInfo* slot) override;
bool IsPublicKeyPresent() override;
// Clears the public and private keys.
void Clear();
// Configures the mock to return the given public key.
void SetPublicKey(const std::vector<uint8_t>& key);
// Sets the public key to use from the given private key, but doesn't
// configure the private key.
void SetPublicKeyFromPrivateKey(crypto::keypair::PrivateKey key);
// Imports the private key into NSS, so it can be found later.
// Also extracts the public key and sets it for this mock object (equivalent
// to calling `SetPublicKeyFromPrivateKey`).
void ImportPrivateKeyAndSetPublicKey(crypto::keypair::PrivateKey key);
// Same as ImportPrivateKeyAndSetPublicKey, but remembers in which slot the
// key is supposed to be. FindPrivateKeyInSlot will take this into account.
void ImportPrivateKeyInSlotAndSetPublicKey(crypto::keypair::PrivateKey key,
PK11SlotInfo* slot);
// Makes next `fail_times` number of calls to OwnerKeyUtil::GenerateKeyPair
// fail.
void SimulateGenerateKeyFailure(int fail_times);
private:
~MockOwnerKeyUtil() override;
void ImportPrivateKeyAndSetPublicKeyImpl(crypto::keypair::PrivateKey key,
PK11SlotInfo* slot);
int generate_key_fail_times_ = 0;
std::vector<uint8_t> public_key_;
std::optional<CK_SLOT_ID> private_key_slot_id_;
crypto::ScopedSECKEYPrivateKey private_key_;
};
} // namespace ownership
#endif // COMPONENTS_OWNERSHIP_MOCK_OWNER_KEY_UTIL_H_
|