forked from chromium/chromium
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfake_secure_message_delegate.h
54 lines (43 loc) · 1.92 KB
/
fake_secure_message_delegate.h
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
// Copyright 2015 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_CRYPTAUTH_FAKE_SECURE_MESSAGE_DELEGATE_H_
#define COMPONENTS_CRYPTAUTH_FAKE_SECURE_MESSAGE_DELEGATE_H_
#include "base/macros.h"
#include "components/cryptauth/secure_message_delegate.h"
namespace cryptauth {
// Fake implementation of SecureMessageDelegate used in tests.
// For clarity in tests, all functions in this delegate will invoke their
// callback with the result before returning.
class FakeSecureMessageDelegate : public SecureMessageDelegate {
public:
FakeSecureMessageDelegate();
~FakeSecureMessageDelegate() override;
// SecureMessageDelegate:
void GenerateKeyPair(const GenerateKeyPairCallback& callback) override;
void DeriveKey(const std::string& private_key,
const std::string& public_key,
const DeriveKeyCallback& callback) override;
void CreateSecureMessage(
const std::string& payload,
const std::string& key,
const CreateOptions& create_options,
const CreateSecureMessageCallback& callback) override;
void UnwrapSecureMessage(
const std::string& serialized_message,
const std::string& key,
const UnwrapOptions& unwrap_options,
const UnwrapSecureMessageCallback& callback) override;
// Returns the corresponding private key for the given |public_key|.
std::string GetPrivateKeyForPublicKey(const std::string& public_key);
// Sets the next public key to be returned by GenerateKeyPair(). The
// corresponding private key will be derived from this public key.
void set_next_public_key(const std::string& public_key) {
next_public_key_ = public_key;
}
private:
std::string next_public_key_;
DISALLOW_COPY_AND_ASSIGN(FakeSecureMessageDelegate);
};
} // namespace cryptauth
#endif // COMPONENTS_CRYPTAUTH_FAKE_SECURE_MESSAGE_DELEGATE_H_