Index: google_apis/gcm/engine/gcm_checkin_request.cc |
diff --git a/google_apis/gcm/engine/gcm_checkin_request.cc b/google_apis/gcm/engine/gcm_checkin_request.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..1f9da8ede37373168f13f8b7e1f8433a0277b470 |
--- /dev/null |
+++ b/google_apis/gcm/engine/gcm_checkin_request.cc |
@@ -0,0 +1,107 @@ |
+// Copyright (c) 2013 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. |
+ |
+#include "google_apis/gcm/engine/gcm_checkin_request.h" |
+ |
+#include "base/bind.h" |
+#include "base/message_loop/message_loop.h" |
+#include "base/values.h" |
+#include "google_apis/gcm/protocol/checkin.pb.h" |
+#include "net/http/http_status_code.h" |
+#include "net/url_request/url_fetcher.h" |
+#include "net/url_request/url_request_status.h" |
+#include "url/gurl.h" |
+ |
+namespace checkin_proto { |
+class AndroidCheckinProto; |
+class AndroidCheckinRequest; |
+class ChromeBuildProto; |
+}; |
+ |
+namespace gcm { |
+ |
+namespace { |
+const char kCheckinURL[] = "https://android.clients.google.com/checkin"; |
+ |
+// Checkin request constants. |
+const char kRequestDataFormat[] = "application/x-protobuf"; |
jianli
2014/01/04 01:34:10
nit: kRequestContentType
fgorski
2014/01/06 20:34:12
Done.
|
+const int kRequestVersionValue = 2; |
+ |
+} // namespace |
+ |
+GCMCheckinRequest::GCMCheckinRequest( |
+ const base::Callback<void(uint64, uint64)>& callback, |
+ net::URLRequestContextGetter* request_context_getter, |
+ const GCMClient::ChromeCheckInInfo& chrome_checkin_info, |
+ int64 user_serial_number, |
+ const GCMClient::CheckInInfo& checkin_info) |
+ : request_context_getter_(request_context_getter), |
+ callback_(callback), |
+ chrome_checkin_info_(chrome_checkin_info), |
+ android_id_(checkin_info.android_id), |
+ security_token_(checkin_info.secret), |
+ user_serial_number_(user_serial_number) {} |
+ |
+GCMCheckinRequest::~GCMCheckinRequest() {} |
+ |
+void GCMCheckinRequest::Start() { |
+ DCHECK(!url_fetcher_.get()); |
+ |
+ checkin_proto::AndroidCheckinRequest request; |
+ request.set_id(android_id_); |
+ request.set_security_token(security_token_); |
+ request.set_user_serial_number(user_serial_number_); |
+ |
+ checkin_proto::ChromeBuildProto* chrome_build = |
+ new checkin_proto::ChromeBuildProto(); |
+ chrome_build->set_platform(chrome_checkin_info_.platform); |
+ chrome_build->set_channel(chrome_checkin_info_.channel); |
+ chrome_build->set_chrome_version(chrome_checkin_info_.chrome_version); |
+ |
+ checkin_proto::AndroidCheckinProto* checkin = |
+ new checkin_proto::AndroidCheckinProto(); |
Nicolas Zea
2014/01/04 01:40:19
you can just do request->mutable_checkin_proto and
fgorski
2014/01/06 20:34:12
Yep. That is my first time manipulating complex pr
|
+ checkin->set_allocated_chrome_build(chrome_build); |
+#if defined(CHROME_OS) |
+ checkin->set_type(checkin_proto::DEVICE_CHROME_OS); |
+#else |
+ checkin->set_type(checkin_proto::DEVICE_CHROME_BROWSER); |
+#endif |
+ |
+ request.set_allocated_checkin(checkin); |
+ request.set_version(kRequestVersionValue); |
+ |
+ std::string upload_data; |
+ CHECK(request.SerializeToString(&upload_data)); |
+ |
+ url_fetcher_.reset( |
+ net::URLFetcher::Create(GURL(kCheckinURL), net::URLFetcher::POST, this)); |
+ url_fetcher_->SetRequestContext(request_context_getter_); |
+ url_fetcher_->SetUploadData(kRequestDataFormat, upload_data); |
+ url_fetcher_->Start(); |
+} |
+ |
+void GCMCheckinRequest::OnURLFetchComplete(const net::URLFetcher* source) { |
+ std::string response_string; |
+ checkin_proto::AndroidCheckinResponse response_proto; |
+ if (!source->GetStatus().is_success() || |
+ source->GetResponseCode() != net::HTTP_OK || |
+ !source->GetResponseAsString(&response_string) || |
+ !response_proto.ParseFromString(response_string)) { |
+ LOG(ERROR) << "Failed to get checkin response."; |
+ callback_.Run(0, 0); |
Nicolas Zea
2014/01/04 01:40:19
I wonder if we should have the retry logic built i
fgorski
2014/01/06 20:34:12
Let's add that in a separate step.
|
+ return; |
+ } |
+ |
+ if (!response_proto.has_android_id() || |
+ !response_proto.has_security_token() || |
+ response_proto.android_id() <= 0) { |
jianli
2014/01/04 01:34:10
android_id is uint64. So the check should be == 0.
fgorski
2014/01/06 20:34:12
As mentioned elsewhere, I suspect it actually is i
|
+ LOG(ERROR) << "Badly formatted checkin response."; |
Nicolas Zea
2014/01/04 01:40:19
Will these always be there on non-first time check
fgorski
2014/01/06 20:34:12
What do you mean. Even if it is the first time che
|
+ callback_.Run(0, 0); |
+ return; |
+ } |
+ |
+ callback_.Run(response_proto.android_id(), response_proto.security_token()); |
+} |
+ |
+} // namespace gcm |