OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "components/cryptauth/cryptauth_client_impl.h" | 5 #include "components/cryptauth/cryptauth_client_impl.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "base/bind.h" | 9 #include "base/bind.h" |
10 #include "base/command_line.h" | 10 #include "base/command_line.h" |
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
53 std::unique_ptr<CryptAuthAccessTokenFetcher> access_token_fetcher, | 53 std::unique_ptr<CryptAuthAccessTokenFetcher> access_token_fetcher, |
54 scoped_refptr<net::URLRequestContextGetter> url_request_context, | 54 scoped_refptr<net::URLRequestContextGetter> url_request_context, |
55 const DeviceClassifier& device_classifier) | 55 const DeviceClassifier& device_classifier) |
56 : api_call_flow_(std::move(api_call_flow)), | 56 : api_call_flow_(std::move(api_call_flow)), |
57 access_token_fetcher_(std::move(access_token_fetcher)), | 57 access_token_fetcher_(std::move(access_token_fetcher)), |
58 url_request_context_(url_request_context), | 58 url_request_context_(url_request_context), |
59 device_classifier_(device_classifier), | 59 device_classifier_(device_classifier), |
60 has_call_started_(false), | 60 has_call_started_(false), |
61 weak_ptr_factory_(this) {} | 61 weak_ptr_factory_(this) {} |
62 | 62 |
63 CryptAuthClientImpl::~CryptAuthClientImpl() { | 63 CryptAuthClientImpl::~CryptAuthClientImpl() { |
sacomoto
2017/06/15 06:13:23
For all requests:
destination: GOOGLE_OWNED_SERVI
Ramin Halavati
2017/06/16 09:48:18
Done.
| |
64 } | 64 } |
65 | 65 |
66 void CryptAuthClientImpl::GetMyDevices( | 66 void CryptAuthClientImpl::GetMyDevices( |
sacomoto
2017/06/15 06:13:19
Currently, this request (and the SendDeviceSyncTic
Ramin Halavati
2017/06/16 09:48:17
I moved the annotation to the caller function so t
| |
67 const GetMyDevicesRequest& request, | 67 const GetMyDevicesRequest& request, |
68 const GetMyDevicesCallback& callback, | 68 const GetMyDevicesCallback& callback, |
69 const ErrorCallback& error_callback) { | 69 const ErrorCallback& error_callback) { |
70 MakeApiCall(kGetMyDevicesPath, request, callback, error_callback); | 70 net::PartialNetworkTrafficAnnotationTag partial_traffic_annotation = |
71 net::DefinePartialNetworkTrafficAnnotation("...", "oauth2_api_call_flow", | |
sacomoto
2017/06/15 06:13:23
cryptauth_get_my_devices
Ramin Halavati
2017/06/16 09:48:18
Acknowledged.
| |
72 R"( | |
73 semantics { | |
74 sender: "..." | |
75 description: "..." | |
76 trigger: "..." | |
77 data: "..." | |
78 destination: WEBSITE/GOOGLE_OWNED_SERVICE/OTHER/LOCAL | |
79 } | |
80 policy { | |
81 setting: "..." | |
82 chrome_policy { | |
83 [POLICY_NAME] { | |
84 policy_options {mode: MANDATORY/RECOMMENDED/UNSET} | |
85 [POLICY_NAME]: ... //(value to disable it) | |
86 } | |
87 } | |
88 policy_exception_justification: "..." | |
89 })"); | |
90 MakeApiCall(kGetMyDevicesPath, request, callback, error_callback, | |
91 partial_traffic_annotation); | |
71 } | 92 } |
72 | 93 |
73 void CryptAuthClientImpl::FindEligibleUnlockDevices( | 94 void CryptAuthClientImpl::FindEligibleUnlockDevices( |
74 const FindEligibleUnlockDevicesRequest& request, | 95 const FindEligibleUnlockDevicesRequest& request, |
75 const FindEligibleUnlockDevicesCallback& callback, | 96 const FindEligibleUnlockDevicesCallback& callback, |
76 const ErrorCallback& error_callback) { | 97 const ErrorCallback& error_callback) { |
77 MakeApiCall(kFindEligibleUnlockDevicesPath, request, callback, | 98 net::PartialNetworkTrafficAnnotationTag partial_traffic_annotation = |
78 error_callback); | 99 net::DefinePartialNetworkTrafficAnnotation("...", "oauth2_api_call_flow", |
sacomoto
2017/06/15 06:13:15
cryptauth_find_eligible_unlock_devices
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
100 R"( | |
101 semantics { | |
102 sender: "..." | |
sacomoto
2017/06/15 06:13:11
CryptAuth Device Manager.
Ramin Halavati
2017/06/16 09:48:16
Done.
| |
103 description: "..." | |
sacomoto
2017/06/15 06:13:12
Gets the list of mobile devices that can be used b
Ramin Halavati
2017/06/16 09:48:16
Done.
| |
104 trigger: "..." | |
sacomoto
2017/06/15 06:13:11
This request is sent when the user starts the Smar
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
105 data: "..." | |
sacomoto
2017/06/15 06:13:11
The device's public key.
Ramin Halavati
2017/06/16 09:48:18
Done.
| |
106 destination: WEBSITE/GOOGLE_OWNED_SERVICE/OTHER/LOCAL | |
107 } | |
108 policy { | |
109 setting: "..." | |
sacomoto
2017/06/15 06:13:10
This request will only be send if the user explici
Ramin Halavati
2017/06/16 09:48:16
Done.
| |
110 chrome_policy { | |
111 [POLICY_NAME] { | |
sacomoto
2017/06/15 06:13:23
EasyUnlockAllowed
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
112 policy_options {mode: MANDATORY/RECOMMENDED/UNSET} | |
sacomoto
2017/06/15 06:13:11
MANDATORY.
Ramin Halavati
2017/06/16 09:48:17
We are removing this field as it's always MANDATOR
| |
113 [POLICY_NAME]: ... //(value to disable it) | |
sacomoto
2017/06/15 06:13:17
EasyUnlockAllowed: false
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
114 } | |
115 } | |
116 policy_exception_justification: "..." | |
117 })"); | |
118 MakeApiCall(kFindEligibleUnlockDevicesPath, request, callback, error_callback, | |
119 partial_traffic_annotation); | |
79 } | 120 } |
80 | 121 |
81 void CryptAuthClientImpl::SendDeviceSyncTickle( | 122 void CryptAuthClientImpl::SendDeviceSyncTickle( |
82 const SendDeviceSyncTickleRequest& request, | 123 const SendDeviceSyncTickleRequest& request, |
83 const SendDeviceSyncTickleCallback& callback, | 124 const SendDeviceSyncTickleCallback& callback, |
84 const ErrorCallback& error_callback) { | 125 const ErrorCallback& error_callback) { |
85 MakeApiCall(kSendDeviceSyncTicklePath, request, callback, error_callback); | 126 net::PartialNetworkTrafficAnnotationTag partial_traffic_annotation = |
127 net::DefinePartialNetworkTrafficAnnotation("...", "oauth2_api_call_flow", | |
sacomoto
2017/06/15 06:13:11
cryptauth_device_sync_tickle
Ramin Halavati
2017/06/16 09:48:17
Acknowledged.
| |
128 R"( | |
129 semantics { | |
130 sender: "..." | |
131 description: "..." | |
132 trigger: "..." | |
133 data: "..." | |
134 destination: WEBSITE/GOOGLE_OWNED_SERVICE/OTHER/LOCAL | |
135 } | |
136 policy { | |
137 setting: "..." | |
138 chrome_policy { | |
139 [POLICY_NAME] { | |
140 policy_options {mode: MANDATORY/RECOMMENDED/UNSET} | |
141 [POLICY_NAME]: ... //(value to disable it) | |
142 } | |
143 } | |
144 policy_exception_justification: "..." | |
145 })"); | |
146 MakeApiCall(kSendDeviceSyncTicklePath, request, callback, error_callback, | |
147 partial_traffic_annotation); | |
86 } | 148 } |
87 | 149 |
88 void CryptAuthClientImpl::ToggleEasyUnlock( | 150 void CryptAuthClientImpl::ToggleEasyUnlock( |
89 const ToggleEasyUnlockRequest& request, | 151 const ToggleEasyUnlockRequest& request, |
90 const ToggleEasyUnlockCallback& callback, | 152 const ToggleEasyUnlockCallback& callback, |
91 const ErrorCallback& error_callback) { | 153 const ErrorCallback& error_callback) { |
92 MakeApiCall(kToggleEasyUnlockPath, request, callback, error_callback); | 154 net::PartialNetworkTrafficAnnotationTag partial_traffic_annotation = |
155 net::DefinePartialNetworkTrafficAnnotation("...", "oauth2_api_call_flow", | |
sacomoto
2017/06/15 06:13:14
cryptauth_toggle_easyunlock
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
156 R"( | |
157 semantics { | |
158 sender: "..." | |
sacomoto
2017/06/15 06:13:11
CryptAuth Device Manager
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
159 description: "..." | |
sacomoto
2017/06/15 06:13:11
Enables Smart Lock (EasyUnlock) for the current de
Ramin Halavati
2017/06/16 09:48:16
Done.
| |
160 trigger: "..." | |
sacomoto
2017/06/15 06:13:16
This request is send after the user goes through t
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
161 data: "..." | |
sacomoto
2017/06/15 06:13:11
The device public key.
Ramin Halavati
2017/06/16 09:48:16
Done.
| |
162 destination: WEBSITE/GOOGLE_OWNED_SERVICE/OTHER/LOCAL | |
163 } | |
164 policy { | |
165 setting: "..." | |
sacomoto
2017/06/15 06:13:15
This will only be send if the user explicitly enab
Ramin Halavati
2017/06/16 09:48:18
Done.
| |
166 chrome_policy { | |
167 [POLICY_NAME] { | |
sacomoto
2017/06/15 06:13:10
EasyUnlockAllowed
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
168 policy_options {mode: MANDATORY/RECOMMENDED/UNSET} | |
sacomoto
2017/06/15 06:13:21
MANDATORY
Ramin Halavati
2017/06/16 09:48:16
Acknowledged.
| |
169 [POLICY_NAME]: ... //(value to disable it) | |
sacomoto
2017/06/15 06:13:10
EasyUnlockAllowed: false
Ramin Halavati
2017/06/16 09:48:16
Done.
| |
170 } | |
171 } | |
172 policy_exception_justification: "..." | |
173 })"); | |
174 MakeApiCall(kToggleEasyUnlockPath, request, callback, error_callback, | |
175 partial_traffic_annotation); | |
93 } | 176 } |
94 | 177 |
95 void CryptAuthClientImpl::SetupEnrollment( | 178 void CryptAuthClientImpl::SetupEnrollment( |
96 const SetupEnrollmentRequest& request, | 179 const SetupEnrollmentRequest& request, |
97 const SetupEnrollmentCallback& callback, | 180 const SetupEnrollmentCallback& callback, |
98 const ErrorCallback& error_callback) { | 181 const ErrorCallback& error_callback) { |
99 MakeApiCall(kSetupEnrollmentPath, request, callback, error_callback); | 182 net::PartialNetworkTrafficAnnotationTag partial_traffic_annotation = |
183 net::DefinePartialNetworkTrafficAnnotation("...", "oauth2_api_call_flow", | |
sacomoto
2017/06/15 06:13:11
cryptauth_enrollment_flow_setup
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
184 R"( | |
185 semantics { | |
186 sender: "..." | |
sacomoto
2017/06/15 06:13:23
CryptAuth Enrollment Manager
Ramin Halavati
2017/06/16 09:48:16
Done.
| |
187 description: "..." | |
sacomoto
2017/06/15 06:13:20
Starts the CryptAuth registration flow.
Ramin Halavati
2017/06/16 09:48:18
Done.
| |
188 trigger: "..." | |
sacomoto
2017/06/15 06:13:10
Occurs periodically, at least once a month.
Ramin Halavati
2017/06/16 09:48:16
Done.
| |
189 data: "..." | |
sacomoto
2017/06/15 06:13:23
Various device information (public key, bluetooth
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
190 destination: WEBSITE/GOOGLE_OWNED_SERVICE/OTHER/LOCAL | |
191 } | |
192 policy { | |
193 setting: "..." | |
sacomoto
2017/06/15 06:13:18
This feature cannot be disabled by settings. Howev
Ramin Halavati
2017/06/16 09:48:18
Done.
| |
194 chrome_policy { | |
sacomoto
2017/06/15 06:13:10
There is no policy covering this request.
Ramin Halavati
2017/06/16 09:48:17
How about 'SigninAllowed'?
sacomoto
2017/06/19 18:25:38
Yes, you are right. This policy would disable all
Ramin Halavati
2017/06/20 05:35:33
Acknowledged.
| |
195 [POLICY_NAME] { | |
196 policy_options {mode: MANDATORY/RECOMMENDED/UNSET} | |
197 [POLICY_NAME]: ... //(value to disable it) | |
198 } | |
199 } | |
200 policy_exception_justification: "..." | |
201 })"); | |
202 MakeApiCall(kSetupEnrollmentPath, request, callback, error_callback, | |
203 partial_traffic_annotation); | |
100 } | 204 } |
101 | 205 |
102 void CryptAuthClientImpl::FinishEnrollment( | 206 void CryptAuthClientImpl::FinishEnrollment( |
103 const FinishEnrollmentRequest& request, | 207 const FinishEnrollmentRequest& request, |
104 const FinishEnrollmentCallback& callback, | 208 const FinishEnrollmentCallback& callback, |
105 const ErrorCallback& error_callback) { | 209 const ErrorCallback& error_callback) { |
106 MakeApiCall(kFinishEnrollmentPath, request, callback, error_callback); | 210 net::PartialNetworkTrafficAnnotationTag partial_traffic_annotation = |
211 net::DefinePartialNetworkTrafficAnnotation("...", "oauth2_api_call_flow", | |
sacomoto
2017/06/15 06:13:23
cryptauth_enrollment_flow_finish
Ramin Halavati
2017/06/16 09:48:16
Done.
| |
212 R"( | |
213 semantics { | |
214 sender: "..." | |
sacomoto
2017/06/15 06:13:11
CryptAuth Enrollment Manager
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
215 description: "..." | |
sacomoto
2017/06/15 06:13:23
Finishes the CryptAuth registration flow.
Ramin Halavati
2017/06/16 09:48:18
Done.
| |
216 trigger: "..." | |
sacomoto
2017/06/15 06:13:22
Occurs periodically, at least once a month.
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
217 data: "..." | |
Ramin Halavati
2017/06/16 09:48:17
None?
| |
218 destination: WEBSITE/GOOGLE_OWNED_SERVICE/OTHER/LOCAL | |
219 } | |
220 policy { | |
221 setting: "..." | |
sacomoto
2017/06/15 06:13:10
This feature cannot be disabled by settings. Howev
Ramin Halavati
2017/06/16 09:48:17
Done.
| |
222 chrome_policy { | |
sacomoto
2017/06/15 06:13:23
There is no policy covering this request.
Ramin Halavati
2017/06/16 09:48:16
Acknowledged.
| |
223 [POLICY_NAME] { | |
224 policy_options {mode: MANDATORY/RECOMMENDED/UNSET} | |
225 [POLICY_NAME]: ... //(value to disable it) | |
226 } | |
227 } | |
228 policy_exception_justification: "..." | |
229 })"); | |
230 MakeApiCall(kFinishEnrollmentPath, request, callback, error_callback, | |
231 partial_traffic_annotation); | |
107 } | 232 } |
108 | 233 |
109 std::string CryptAuthClientImpl::GetAccessTokenUsed() { | 234 std::string CryptAuthClientImpl::GetAccessTokenUsed() { |
110 return access_token_used_; | 235 return access_token_used_; |
111 } | 236 } |
112 | 237 |
113 template <class RequestProto, class ResponseProto> | 238 template <class RequestProto, class ResponseProto> |
114 void CryptAuthClientImpl::MakeApiCall( | 239 void CryptAuthClientImpl::MakeApiCall( |
115 const std::string& request_path, | 240 const std::string& request_path, |
116 const RequestProto& request_proto, | 241 const RequestProto& request_proto, |
117 const base::Callback<void(const ResponseProto&)>& response_callback, | 242 const base::Callback<void(const ResponseProto&)>& response_callback, |
118 const ErrorCallback& error_callback) { | 243 const ErrorCallback& error_callback, |
244 const net::PartialNetworkTrafficAnnotationTag& partial_traffic_annotation) { | |
119 if (has_call_started_) { | 245 if (has_call_started_) { |
120 error_callback.Run( | 246 error_callback.Run( |
121 "Client has been used for another request. Do not reuse."); | 247 "Client has been used for another request. Do not reuse."); |
122 return; | 248 return; |
123 } | 249 } |
124 has_call_started_ = true; | 250 has_call_started_ = true; |
125 | 251 |
252 api_call_flow_->SetPartialNetworkTrafficAnnotation( | |
253 partial_traffic_annotation); | |
254 | |
126 // The |device_classifier| field must be present for all CryptAuth requests. | 255 // The |device_classifier| field must be present for all CryptAuth requests. |
127 RequestProto request_copy(request_proto); | 256 RequestProto request_copy(request_proto); |
128 request_copy.mutable_device_classifier()->CopyFrom(device_classifier_); | 257 request_copy.mutable_device_classifier()->CopyFrom(device_classifier_); |
129 | 258 |
130 std::string serialized_request; | 259 std::string serialized_request; |
131 if (!request_copy.SerializeToString(&serialized_request)) { | 260 if (!request_copy.SerializeToString(&serialized_request)) { |
132 error_callback.Run(std::string("Failed to serialize ") + | 261 error_callback.Run(std::string("Failed to serialize ") + |
133 request_proto.GetTypeName() + " proto."); | 262 request_proto.GetTypeName() + " proto."); |
134 return; | 263 return; |
135 } | 264 } |
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
194 | 323 |
195 std::unique_ptr<CryptAuthClient> CryptAuthClientFactoryImpl::CreateInstance() { | 324 std::unique_ptr<CryptAuthClient> CryptAuthClientFactoryImpl::CreateInstance() { |
196 return base::MakeUnique<CryptAuthClientImpl>( | 325 return base::MakeUnique<CryptAuthClientImpl>( |
197 base::WrapUnique(new CryptAuthApiCallFlow()), | 326 base::WrapUnique(new CryptAuthApiCallFlow()), |
198 base::WrapUnique( | 327 base::WrapUnique( |
199 new CryptAuthAccessTokenFetcherImpl(token_service_, account_id_)), | 328 new CryptAuthAccessTokenFetcherImpl(token_service_, account_id_)), |
200 url_request_context_, device_classifier_); | 329 url_request_context_, device_classifier_); |
201 } | 330 } |
202 | 331 |
203 } // namespace cryptauth | 332 } // namespace cryptauth |
OLD | NEW |