| 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/signin/core/browser/refresh_token_annotation_request.h" | 5 #include "components/signin/core/browser/refresh_token_annotation_request.h" |
| 6 | 6 |
| 7 #include "base/message_loop/message_loop.h" | 7 #include "base/location.h" |
| 8 #include "base/metrics/histogram_macros.h" | 8 #include "base/metrics/histogram_macros.h" |
| 9 #include "base/prefs/pref_service.h" | 9 #include "base/prefs/pref_service.h" |
| 10 #include "base/rand_util.h" | 10 #include "base/rand_util.h" |
| 11 #include "base/single_thread_task_runner.h" |
| 11 #include "base/strings/stringprintf.h" | 12 #include "base/strings/stringprintf.h" |
| 13 #include "base/thread_task_runner_handle.h" |
| 12 #include "base/time/time.h" | 14 #include "base/time/time.h" |
| 13 #include "components/signin/core/browser/signin_client.h" | 15 #include "components/signin/core/browser/signin_client.h" |
| 14 #include "components/signin/core/common/signin_pref_names.h" | 16 #include "components/signin/core/common/signin_pref_names.h" |
| 15 #include "google_apis/gaia/gaia_constants.h" | 17 #include "google_apis/gaia/gaia_constants.h" |
| 16 #include "google_apis/gaia/gaia_urls.h" | 18 #include "google_apis/gaia/gaia_urls.h" |
| 17 #include "net/base/escape.h" | 19 #include "net/base/escape.h" |
| 18 #include "net/url_request/url_request_context_getter.h" | 20 #include "net/url_request/url_request_context_getter.h" |
| 19 | 21 |
| 20 namespace { | 22 namespace { |
| 21 | 23 |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 114 DVLOG(2) << "Got access token"; | 116 DVLOG(2) << "Got access token"; |
| 115 Start(request_context_getter_.get(), access_token); | 117 Start(request_context_getter_.get(), access_token); |
| 116 } | 118 } |
| 117 | 119 |
| 118 void RefreshTokenAnnotationRequest::OnGetTokenFailure( | 120 void RefreshTokenAnnotationRequest::OnGetTokenFailure( |
| 119 const OAuth2TokenService::Request* request, | 121 const OAuth2TokenService::Request* request, |
| 120 const GoogleServiceAuthError& error) { | 122 const GoogleServiceAuthError& error) { |
| 121 DCHECK(CalledOnValidThread()); | 123 DCHECK(CalledOnValidThread()); |
| 122 DVLOG(2) << "Failed to get access token"; | 124 DVLOG(2) << "Failed to get access token"; |
| 123 RecordRequestStatusHistogram(false); | 125 RecordRequestStatusHistogram(false); |
| 124 base::MessageLoop::current()->PostTask(FROM_HERE, request_callback_); | 126 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, request_callback_); |
| 125 request_callback_.Reset(); | 127 request_callback_.Reset(); |
| 126 } | 128 } |
| 127 | 129 |
| 128 GURL RefreshTokenAnnotationRequest::CreateApiCallUrl() { | 130 GURL RefreshTokenAnnotationRequest::CreateApiCallUrl() { |
| 129 return GaiaUrls::GetInstance()->oauth2_issue_token_url(); | 131 return GaiaUrls::GetInstance()->oauth2_issue_token_url(); |
| 130 } | 132 } |
| 131 | 133 |
| 132 std::string RefreshTokenAnnotationRequest::CreateApiCallBody() { | 134 std::string RefreshTokenAnnotationRequest::CreateApiCallBody() { |
| 133 // response_type=none means we don't want any token back, just record that | 135 // response_type=none means we don't want any token back, just record that |
| 134 // this request was sent. | 136 // this request was sent. |
| (...skipping 15 matching lines...) Expand all Loading... |
| 150 net::EscapeUrlEncodedData(client_id_, true).c_str(), | 152 net::EscapeUrlEncodedData(client_id_, true).c_str(), |
| 151 net::EscapeUrlEncodedData(device_id_, true).c_str(), | 153 net::EscapeUrlEncodedData(device_id_, true).c_str(), |
| 152 net::EscapeUrlEncodedData(product_version_, true).c_str()); | 154 net::EscapeUrlEncodedData(product_version_, true).c_str()); |
| 153 } | 155 } |
| 154 | 156 |
| 155 void RefreshTokenAnnotationRequest::ProcessApiCallSuccess( | 157 void RefreshTokenAnnotationRequest::ProcessApiCallSuccess( |
| 156 const net::URLFetcher* source) { | 158 const net::URLFetcher* source) { |
| 157 DCHECK(CalledOnValidThread()); | 159 DCHECK(CalledOnValidThread()); |
| 158 DVLOG(2) << "Request succeeded"; | 160 DVLOG(2) << "Request succeeded"; |
| 159 RecordRequestStatusHistogram(true); | 161 RecordRequestStatusHistogram(true); |
| 160 base::MessageLoop::current()->PostTask(FROM_HERE, request_callback_); | 162 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, request_callback_); |
| 161 request_callback_.Reset(); | 163 request_callback_.Reset(); |
| 162 } | 164 } |
| 163 | 165 |
| 164 void RefreshTokenAnnotationRequest::ProcessApiCallFailure( | 166 void RefreshTokenAnnotationRequest::ProcessApiCallFailure( |
| 165 const net::URLFetcher* source) { | 167 const net::URLFetcher* source) { |
| 166 DCHECK(CalledOnValidThread()); | 168 DCHECK(CalledOnValidThread()); |
| 167 DVLOG(2) << "Request failed"; | 169 DVLOG(2) << "Request failed"; |
| 168 RecordRequestStatusHistogram(false); | 170 RecordRequestStatusHistogram(false); |
| 169 base::MessageLoop::current()->PostTask(FROM_HERE, request_callback_); | 171 base::ThreadTaskRunnerHandle::Get()->PostTask(FROM_HERE, request_callback_); |
| 170 request_callback_.Reset(); | 172 request_callback_.Reset(); |
| 171 } | 173 } |
| OLD | NEW |