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

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

Issue 1099553003: Added unit tests for getCredentialsFromAuthCode. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: for review 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_GAIA_OAUTH_CLIENT_H_
6 #define REMOTING_HOST_SETUP_OAUTH_CLIENT 6 #define REMOTING_HOST_SETUP_GAIA_OAUTH_CLIENT_H_
7 7
8 #include <queue> 8 #include <queue>
9 #include <string>
10 9
11 #include "base/callback.h"
12 #include "base/memory/ref_counted.h" 10 #include "base/memory/ref_counted.h"
13 #include "google_apis/gaia/gaia_oauth_client.h" 11 #include "google_apis/gaia/gaia_oauth_client.h"
14 #include "net/url_request/url_request_context_getter.h" 12 #include "net/url_request/url_request_context_getter.h"
15 13
14 #include "remoting/host/setup/oauth_client.h"
15
16 namespace net { 16 namespace net {
17 class URLRequestContext; 17 class URLRequestContext;
18 } 18 }
19 19
20 namespace remoting { 20 namespace remoting {
21 21
22 // A wrapper around GaiaOAuthClient that provides a more convenient interface, 22 // A wrapper around gaia::GaiaOAuthClient that provides a more
23 // with queueing of requests and a callback rather than a delegate. 23 // convenient interface, with queueing of requests and a callback
24 class OAuthClient : public gaia::GaiaOAuthClient::Delegate { 24 // rather than a delegate.
25 class GaiaOAuthClient :
26 public OAuthClient,
Lambros 2015/04/24 21:38:56 Move this to the line above. Then the next 'public
John Williams 2015/04/24 21:48:42 Done.
27 public gaia::GaiaOAuthClient::Delegate {
25 public: 28 public:
26 // Called when GetCredentialsFromAuthCode is completed, with the |user_email| 29 GaiaOAuthClient(
27 // and |refresh_token| that correspond to the given |auth_code|, or with empty
28 // strings on error.
29 typedef base::Callback<void(
30 const std::string& user_email,
31 const std::string& refresh_token)> CompletionCallback;
32
33 OAuthClient(
34 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter); 30 scoped_refptr<net::URLRequestContextGetter> url_request_context_getter);
35 31
36 ~OAuthClient() override; 32 ~GaiaOAuthClient() override;
37 33
38 // Redeems |auth_code| using |oauth_client_info| to obtain |refresh_token| and 34 // Redeems |auth_code| using |oauth_client_info| to obtain |refresh_token| and
39 // |access_token|, then uses the userinfo endpoint to obtain |user_email|. 35 // |access_token|, then uses the userinfo endpoint to obtain |user_email|.
40 // Calls CompletionCallback with |user_email| and |refresh_token| when done, 36 // Calls CompletionCallback with |user_email| and |refresh_token| when done,
41 // or with empty strings on error. 37 // or with empty strings on error.
42 // If a request is received while another one is being processed, it is 38 // If a request is received while another one is being processed, it is
43 // enqueued and processed after the first one is finished. 39 // enqueued and processed after the first one is finished.
44 void GetCredentialsFromAuthCode( 40 void GetCredentialsFromAuthCode(
45 const gaia::OAuthClientInfo& oauth_client_info, 41 const gaia::OAuthClientInfo& oauth_client_info,
46 const std::string& auth_code, 42 const std::string& auth_code,
47 CompletionCallback on_done); 43 CompletionCallback on_done) override;
48 44
49 // gaia::GaiaOAuthClient::Delegate 45 // gaia::GaiaOAuthClient::Delegate
50 void OnGetTokensResponse(const std::string& refresh_token, 46 void OnGetTokensResponse(const std::string& refresh_token,
51 const std::string& access_token, 47 const std::string& access_token,
52 int expires_in_seconds) override; 48 int expires_in_seconds) override;
53 void OnRefreshTokenResponse(const std::string& access_token, 49 void OnRefreshTokenResponse(const std::string& access_token,
54 int expires_in_seconds) override; 50 int expires_in_seconds) override;
55 void OnGetUserEmailResponse(const std::string& user_email) override; 51 void OnGetUserEmailResponse(const std::string& user_email) override;
56 52
57 void OnOAuthError() override; 53 void OnOAuthError() override;
(...skipping 11 matching lines...) Expand all
69 }; 65 };
70 66
71 void SendResponse(const std::string& user_email, 67 void SendResponse(const std::string& user_email,
72 const std::string& refresh_token); 68 const std::string& refresh_token);
73 69
74 std::queue<Request> pending_requests_; 70 std::queue<Request> pending_requests_;
75 gaia::GaiaOAuthClient gaia_oauth_client_; 71 gaia::GaiaOAuthClient gaia_oauth_client_;
76 std::string refresh_token_; 72 std::string refresh_token_;
77 CompletionCallback on_done_; 73 CompletionCallback on_done_;
78 74
79 DISALLOW_COPY_AND_ASSIGN(OAuthClient); 75 DISALLOW_COPY_AND_ASSIGN(GaiaOAuthClient);
80 }; 76 };
81 77
82 } // namespace remoting 78 } // namespace remoting
83 79
84 #endif // REMOTING_HOST_SETUP_OAUTH_CLIENT 80 #endif // REMOTING_HOST_SETUP_GAIA_OAUTH_CLIENT_H_
OLDNEW
« no previous file with comments | « no previous file | remoting/host/setup/gaia_oauth_client.cc » ('j') | remoting/host/setup/gaia_oauth_client.cc » ('J')

Powered by Google App Engine
This is Rietveld 408576698