Updating trunk VERSION from 2139.0 to 2140.0
[chromium-blink-merge.git] / chromeos / dbus / fake_cryptohome_client.h
blobeac6f0a25b63b9a3d857b92e51b794c47d6fff52
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef CHROMEOS_DBUS_FAKE_CRYPTOHOME_CLIENT_H_
6 #define CHROMEOS_DBUS_FAKE_CRYPTOHOME_CLIENT_H_
8 #include <map>
10 #include "base/basictypes.h"
11 #include "base/memory/weak_ptr.h"
12 #include "chromeos/dbus/cryptohome_client.h"
14 namespace chromeos {
16 class CHROMEOS_EXPORT FakeCryptohomeClient : public CryptohomeClient {
17 public:
18 FakeCryptohomeClient();
19 virtual ~FakeCryptohomeClient();
21 virtual void Init(dbus::Bus* bus) OVERRIDE;
22 virtual void SetAsyncCallStatusHandlers(
23 const AsyncCallStatusHandler& handler,
24 const AsyncCallStatusWithDataHandler& data_handler) OVERRIDE;
25 virtual void ResetAsyncCallStatusHandlers() OVERRIDE;
26 virtual void WaitForServiceToBeAvailable(
27 const WaitForServiceToBeAvailableCallback& callback) OVERRIDE;
28 virtual void IsMounted(const BoolDBusMethodCallback& callback) OVERRIDE;
29 virtual bool Unmount(bool* success) OVERRIDE;
30 virtual void AsyncCheckKey(const std::string& username,
31 const std::string& key,
32 const AsyncMethodCallback& callback) OVERRIDE;
33 virtual void AsyncMigrateKey(const std::string& username,
34 const std::string& from_key,
35 const std::string& to_key,
36 const AsyncMethodCallback& callback) OVERRIDE;
37 virtual void AsyncRemove(const std::string& username,
38 const AsyncMethodCallback& callback) OVERRIDE;
39 virtual void GetSystemSalt(const GetSystemSaltCallback& callback) OVERRIDE;
40 virtual void GetSanitizedUsername(
41 const std::string& username,
42 const StringDBusMethodCallback& callback) OVERRIDE;
43 virtual std::string BlockingGetSanitizedUsername(
44 const std::string& username) OVERRIDE;
45 virtual void AsyncMount(const std::string& username,
46 const std::string& key,
47 int flags,
48 const AsyncMethodCallback& callback) OVERRIDE;
49 virtual void AsyncAddKey(const std::string& username,
50 const std::string& key,
51 const std::string& new_key,
52 const AsyncMethodCallback& callback) OVERRIDE;
53 virtual void AsyncMountGuest(const AsyncMethodCallback& callback) OVERRIDE;
54 virtual void AsyncMountPublic(const std::string& public_mount_id,
55 int flags,
56 const AsyncMethodCallback& callback) OVERRIDE;
57 virtual void TpmIsReady(const BoolDBusMethodCallback& callback) OVERRIDE;
58 virtual void TpmIsEnabled(const BoolDBusMethodCallback& callback) OVERRIDE;
59 virtual bool CallTpmIsEnabledAndBlock(bool* enabled) OVERRIDE;
60 virtual void TpmGetPassword(
61 const StringDBusMethodCallback& callback) OVERRIDE;
62 virtual void TpmIsOwned(const BoolDBusMethodCallback& callback) OVERRIDE;
63 virtual bool CallTpmIsOwnedAndBlock(bool* owned) OVERRIDE;
64 virtual void TpmIsBeingOwned(const BoolDBusMethodCallback& callback) OVERRIDE;
65 virtual bool CallTpmIsBeingOwnedAndBlock(bool* owning) OVERRIDE;
66 virtual void TpmCanAttemptOwnership(
67 const VoidDBusMethodCallback& callback) OVERRIDE;
68 virtual void TpmClearStoredPassword(
69 const VoidDBusMethodCallback& callback) OVERRIDE;
70 virtual bool CallTpmClearStoredPasswordAndBlock() OVERRIDE;
71 virtual void Pkcs11IsTpmTokenReady(
72 const BoolDBusMethodCallback& callback) OVERRIDE;
73 virtual void Pkcs11GetTpmTokenInfo(
74 const Pkcs11GetTpmTokenInfoCallback& callback) OVERRIDE;
75 virtual void Pkcs11GetTpmTokenInfoForUser(
76 const std::string& username,
77 const Pkcs11GetTpmTokenInfoCallback& callback) OVERRIDE;
78 virtual bool InstallAttributesGet(const std::string& name,
79 std::vector<uint8>* value,
80 bool* successful) OVERRIDE;
81 virtual bool InstallAttributesSet(const std::string& name,
82 const std::vector<uint8>& value,
83 bool* successful) OVERRIDE;
84 virtual bool InstallAttributesFinalize(bool* successful) OVERRIDE;
85 virtual void InstallAttributesIsReady(
86 const BoolDBusMethodCallback& callback) OVERRIDE;
87 virtual bool InstallAttributesIsInvalid(bool* is_invalid) OVERRIDE;
88 virtual bool InstallAttributesIsFirstInstall(bool* is_first_install) OVERRIDE;
89 virtual void TpmAttestationIsPrepared(
90 const BoolDBusMethodCallback& callback) OVERRIDE;
91 virtual void TpmAttestationIsEnrolled(
92 const BoolDBusMethodCallback& callback) OVERRIDE;
93 virtual void AsyncTpmAttestationCreateEnrollRequest(
94 chromeos::attestation::PrivacyCAType pca_type,
95 const AsyncMethodCallback& callback) OVERRIDE;
96 virtual void AsyncTpmAttestationEnroll(
97 chromeos::attestation::PrivacyCAType pca_type,
98 const std::string& pca_response,
99 const AsyncMethodCallback& callback) OVERRIDE;
100 virtual void AsyncTpmAttestationCreateCertRequest(
101 chromeos::attestation::PrivacyCAType pca_type,
102 attestation::AttestationCertificateProfile certificate_profile,
103 const std::string& user_id,
104 const std::string& request_origin,
105 const AsyncMethodCallback& callback) OVERRIDE;
106 virtual void AsyncTpmAttestationFinishCertRequest(
107 const std::string& pca_response,
108 attestation::AttestationKeyType key_type,
109 const std::string& user_id,
110 const std::string& key_name,
111 const AsyncMethodCallback& callback) OVERRIDE;
112 virtual void TpmAttestationDoesKeyExist(
113 attestation::AttestationKeyType key_type,
114 const std::string& user_id,
115 const std::string& key_name,
116 const BoolDBusMethodCallback& callback) OVERRIDE;
117 virtual void TpmAttestationGetCertificate(
118 attestation::AttestationKeyType key_type,
119 const std::string& user_id,
120 const std::string& key_name,
121 const DataMethodCallback& callback) OVERRIDE;
122 virtual void TpmAttestationGetPublicKey(
123 attestation::AttestationKeyType key_type,
124 const std::string& user_id,
125 const std::string& key_name,
126 const DataMethodCallback& callback) OVERRIDE;
127 virtual void TpmAttestationRegisterKey(
128 attestation::AttestationKeyType key_type,
129 const std::string& user_id,
130 const std::string& key_name,
131 const AsyncMethodCallback& callback) OVERRIDE;
132 virtual void TpmAttestationSignEnterpriseChallenge(
133 attestation::AttestationKeyType key_type,
134 const std::string& user_id,
135 const std::string& key_name,
136 const std::string& domain,
137 const std::string& device_id,
138 attestation::AttestationChallengeOptions options,
139 const std::string& challenge,
140 const AsyncMethodCallback& callback) OVERRIDE;
141 virtual void TpmAttestationSignSimpleChallenge(
142 attestation::AttestationKeyType key_type,
143 const std::string& user_id,
144 const std::string& key_name,
145 const std::string& challenge,
146 const AsyncMethodCallback& callback) OVERRIDE;
147 virtual void TpmAttestationGetKeyPayload(
148 attestation::AttestationKeyType key_type,
149 const std::string& user_id,
150 const std::string& key_name,
151 const DataMethodCallback& callback) OVERRIDE;
152 virtual void TpmAttestationSetKeyPayload(
153 attestation::AttestationKeyType key_type,
154 const std::string& user_id,
155 const std::string& key_name,
156 const std::string& payload,
157 const BoolDBusMethodCallback& callback) OVERRIDE;
158 virtual void TpmAttestationDeleteKeys(
159 attestation::AttestationKeyType key_type,
160 const std::string& user_id,
161 const std::string& key_prefix,
162 const BoolDBusMethodCallback& callback) OVERRIDE;
163 virtual void CheckKeyEx(
164 const cryptohome::AccountIdentifier& id,
165 const cryptohome::AuthorizationRequest& auth,
166 const cryptohome::CheckKeyRequest& request,
167 const ProtobufMethodCallback& callback) OVERRIDE;
168 virtual void MountEx(
169 const cryptohome::AccountIdentifier& id,
170 const cryptohome::AuthorizationRequest& auth,
171 const cryptohome::MountRequest& request,
172 const ProtobufMethodCallback& callback) OVERRIDE;
173 virtual void AddKeyEx(
174 const cryptohome::AccountIdentifier& id,
175 const cryptohome::AuthorizationRequest& auth,
176 const cryptohome::AddKeyRequest& request,
177 const ProtobufMethodCallback& callback) OVERRIDE;
178 virtual void UpdateKeyEx(
179 const cryptohome::AccountIdentifier& id,
180 const cryptohome::AuthorizationRequest& auth,
181 const cryptohome::UpdateKeyRequest& request,
182 const ProtobufMethodCallback& callback) OVERRIDE;
183 virtual void RemoveKeyEx(const cryptohome::AccountIdentifier& id,
184 const cryptohome::AuthorizationRequest& auth,
185 const cryptohome::RemoveKeyRequest& request,
186 const ProtobufMethodCallback& callback) OVERRIDE;
187 virtual void GetBootAttribute(
188 const cryptohome::GetBootAttributeRequest& request,
189 const ProtobufMethodCallback& callback) OVERRIDE;
190 virtual void SetBootAttribute(
191 const cryptohome::SetBootAttributeRequest& request,
192 const ProtobufMethodCallback& callback) OVERRIDE;
193 virtual void FlushAndSignBootAttributes(
194 const cryptohome::FlushAndSignBootAttributesRequest& request,
195 const ProtobufMethodCallback& callback) OVERRIDE;
197 // Changes the behavior of WaitForServiceToBeAvailable(). This method runs
198 // pending callbacks if is_available is true.
199 void SetServiceIsAvailable(bool is_available);
201 // Sets the unmount result of Unmount() call.
202 void set_unmount_result(bool result) {
203 unmount_result_= result;
206 // Sets the system salt which will be returned from GetSystemSalt(). By
207 // default, GetSystemSalt() returns the value generated by
208 // GetStubSystemSalt().
209 void set_system_salt(const std::vector<uint8>& system_salt) {
210 system_salt_ = system_salt;
213 // Returns the stub system salt as raw bytes. (not as a string encoded in the
214 // format used by SystemSaltGetter::ConvertRawSaltToHexString()).
215 static std::vector<uint8> GetStubSystemSalt();
217 private:
218 void ReturnProtobufMethodCallback(
219 const cryptohome::BaseReply& reply,
220 const ProtobufMethodCallback& callback);
222 // Posts tasks which return fake results to the UI thread.
223 void ReturnAsyncMethodResult(const AsyncMethodCallback& callback,
224 bool returns_data);
226 // This method is used to implement ReturnAsyncMethodResult.
227 void ReturnAsyncMethodResultInternal(const AsyncMethodCallback& callback,
228 bool returns_data);
230 bool service_is_available_;
231 int async_call_id_;
232 AsyncCallStatusHandler async_call_status_handler_;
233 AsyncCallStatusWithDataHandler async_call_status_data_handler_;
234 int tpm_is_ready_counter_;
235 bool unmount_result_;
236 std::vector<uint8> system_salt_;
238 std::vector<WaitForServiceToBeAvailableCallback>
239 pending_wait_for_service_to_be_available_callbacks_;
241 // A stub store for InstallAttributes, mapping an attribute name to the
242 // associated data blob. Used to implement InstallAttributesSet and -Get.
243 std::map<std::string, std::vector<uint8> > install_attrs_;
244 bool locked_;
245 base::WeakPtrFactory<FakeCryptohomeClient> weak_ptr_factory_;
247 DISALLOW_COPY_AND_ASSIGN(FakeCryptohomeClient);
250 } // namespace chromeos
252 #endif // CHROMEOS_DBUS_FAKE_CRYPTOHOME_CLIENT_H_