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

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

Issue 1076093003: Added method to host daemon to exchange an auth code for just an OAuth (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 8 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
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 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 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 #ifndef REMOTING_HOST_SETUP_OAUTH_CLIENT 5 #ifndef REMOTING_HOST_SETUP_OAUTH_CLIENT
6 #define REMOTING_HOST_SETUP_OAUTH_CLIENT 6 #define REMOTING_HOST_SETUP_OAUTH_CLIENT
7 7
8 #include <queue> 8 #include <queue>
9 #include <string> 9 #include <string>
10 10
(...skipping 17 matching lines...) Expand all
28 // strings on error. 28 // strings on error.
29 typedef base::Callback<void( 29 typedef base::Callback<void(
30 const std::string& user_email, 30 const std::string& user_email,
31 const std::string& refresh_token)> CompletionCallback; 31 const std::string& refresh_token)> CompletionCallback;
32 32
33 OAuthClient( 33 OAuthClient(
34 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter); 34 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter);
35 35
36 ~OAuthClient() override; 36 ~OAuthClient() override;
37 37
38 // Redeems |auth_code| using |oauth_client_info| to obtain |refresh_token| and 38 // Redeems |auth_code| using |oauth_client_info| to obtain
39 // |access_token|, then uses the userinfo endpoint to obtain |user_email|. 39 // |refresh_token| and |access_token|, then, if |need_user_info| is
Lambros 2015/04/22 18:24:34 s/_info/_email/
John Williams 2015/04/22 20:11:25 Done.
40 // Calls CompletionCallback with |user_email| and |refresh_token| when done, 40 // true, uses the userinfo endpoint to obtain |user_email|. Calls
41 // or with empty strings on error. 41 // CompletionCallback with |user_email| and |refresh_token| when
42 // If a request is received while another one is being processed, it is 42 // done, or with empty strings on error. If a request is received
43 // enqueued and processed after the first one is finished. 43 // while another one is being processed, it is enqueued and
44 // processed after the first one is finished.
44 void GetCredentialsFromAuthCode( 45 void GetCredentialsFromAuthCode(
45 const gaia::OAuthClientInfo& oauth_client_info, 46 const gaia::OAuthClientInfo& oauth_client_info,
46 const std::string& auth_code, 47 const std::string& auth_code,
48 bool need_user_email,
47 CompletionCallback on_done); 49 CompletionCallback on_done);
48 50
49 // gaia::GaiaOAuthClient::Delegate 51 // gaia::GaiaOAuthClient::Delegate
50 void OnGetTokensResponse(const std::string& refresh_token, 52 void OnGetTokensResponse(const std::string& refresh_token,
51 const std::string& access_token, 53 const std::string& access_token,
52 int expires_in_seconds) override; 54 int expires_in_seconds) override;
53 void OnRefreshTokenResponse(const std::string& access_token, 55 void OnRefreshTokenResponse(const std::string& access_token,
54 int expires_in_seconds) override; 56 int expires_in_seconds) override;
55 void OnGetUserEmailResponse(const std::string& user_email) override; 57 void OnGetUserEmailResponse(const std::string& user_email) override;
56 58
57 void OnOAuthError() override; 59 void OnOAuthError() override;
58 void OnNetworkError(int response_code) override; 60 void OnNetworkError(int response_code) override;
59 61
60 private: 62 private:
61 struct Request { 63 struct Request {
62 Request(const gaia::OAuthClientInfo& oauth_client_info, 64 Request(const gaia::OAuthClientInfo& oauth_client_info,
63 const std::string& auth_code, 65 const std::string& auth_code,
66 bool need_user_email,
64 CompletionCallback on_done); 67 CompletionCallback on_done);
65 virtual ~Request(); 68 virtual ~Request();
66 gaia::OAuthClientInfo oauth_client_info; 69 gaia::OAuthClientInfo oauth_client_info;
67 std::string auth_code; 70 std::string auth_code;
71 bool need_user_email;
68 CompletionCallback on_done; 72 CompletionCallback on_done;
69 }; 73 };
70 74
71 void SendResponse(const std::string& user_email, 75 void SendResponse(const std::string& user_email,
72 const std::string& refresh_token); 76 const std::string& refresh_token);
73 77
74 std::queue<Request> pending_requests_; 78 std::queue<Request> pending_requests_;
75 gaia::GaiaOAuthClient gaia_oauth_client_; 79 gaia::GaiaOAuthClient gaia_oauth_client_;
76 std::string refresh_token_; 80 std::string refresh_token_;
81 bool need_user_email_;
77 CompletionCallback on_done_; 82 CompletionCallback on_done_;
78 83
79 DISALLOW_COPY_AND_ASSIGN(OAuthClient); 84 DISALLOW_COPY_AND_ASSIGN(OAuthClient);
80 }; 85 };
81 86
82 } // namespace remoting 87 } // namespace remoting
83 88
84 #endif // REMOTING_HOST_SETUP_OAUTH_CLIENT 89 #endif // REMOTING_HOST_SETUP_OAUTH_CLIENT
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698