Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(139)

Side by Side Diff: remoting/host/setup/oauth_client.cc

Issue 1099553003: Added unit tests for getCredentialsFromAuthCode. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: updated BUILD.gn file Created 5 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « remoting/host/setup/oauth_client.h ('k') | remoting/remoting_host_srcs.gypi » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
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.
4
5 #include "remoting/host/setup/oauth_client.h"
6
7 #include "base/callback_helpers.h"
8 #include "base/logging.h"
9
10 namespace {
11 const int kMaxGaiaRetries = 3;
12 } // namespace
13
14 namespace remoting {
15
16 OAuthClient::OAuthClient(
17 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter)
18 : gaia_oauth_client_(url_request_context_getter.get()) {
19 }
20
21 OAuthClient::~OAuthClient() {
22 }
23
24 void OAuthClient::GetCredentialsFromAuthCode(
25 const gaia::OAuthClientInfo& oauth_client_info,
26 const std::string& auth_code,
27 bool need_user_email,
28 CompletionCallback on_done) {
29
30 if (!on_done_.is_null()) {
31 pending_requests_.push(
32 Request(oauth_client_info, auth_code, need_user_email, on_done));
33 return;
34 }
35
36 need_user_email_ = need_user_email;
37 on_done_ = on_done;
38 // Map the authorization code to refresh and access tokens.
39 gaia_oauth_client_.GetTokensFromAuthCode(oauth_client_info, auth_code,
40 kMaxGaiaRetries, this);
41 }
42
43 void OAuthClient::OnGetTokensResponse(
44 const std::string& refresh_token,
45 const std::string& access_token,
46 int expires_in_seconds) {
47 refresh_token_ = refresh_token;
48 if (need_user_email_) {
49 // Get the email corresponding to the access token.
50 gaia_oauth_client_.GetUserEmail(access_token, kMaxGaiaRetries, this);
51 } else {
52 SendResponse("", refresh_token_);
53 }
54 }
55
56 void OAuthClient::OnRefreshTokenResponse(
57 const std::string& access_token,
58 int expires_in_seconds) {
59 // We never request a refresh token, so this call is not expected.
60 NOTREACHED();
61 }
62
63 void OAuthClient::SendResponse(const std::string& user_email,
64 const std::string& refresh_token) {
65 base::ResetAndReturn(&on_done_).Run(user_email, refresh_token);
66
67 // Process the next request in the queue.
68 if (pending_requests_.size()) {
69 Request request = pending_requests_.front();
70 pending_requests_.pop();
71 // GetCredentialsFromAuthCode is asynchronous, so it's safe to call it here.
72 GetCredentialsFromAuthCode(
73 request.oauth_client_info,
74 request.auth_code,
75 request.need_user_email,
76 request.on_done);
77 }
78 }
79
80 void OAuthClient::OnGetUserEmailResponse(const std::string& user_email) {
81 SendResponse(user_email, refresh_token_);
82 }
83
84 void OAuthClient::OnOAuthError() {
85 SendResponse("", "");
86 }
87
88 void OAuthClient::OnNetworkError(int response_code) {
89 SendResponse("", "");
90 }
91
92 OAuthClient::Request::Request(
93 const gaia::OAuthClientInfo& oauth_client_info,
94 const std::string& auth_code,
95 bool need_user_email,
96 CompletionCallback on_done) {
97 this->oauth_client_info = oauth_client_info;
98 this->auth_code = auth_code;
99 this->need_user_email = need_user_email;
100 this->on_done = on_done;
101 }
102
103 OAuthClient::Request::~Request() {
104 }
105
106 } // namespace remoting
OLDNEW
« no previous file with comments | « remoting/host/setup/oauth_client.h ('k') | remoting/remoting_host_srcs.gypi » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698