OLD | NEW |
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 CHROME_BROWSER_SIGNIN_ANDROID_PROFILE_OAUTH2_TOKEN_SERVICE_H_ | 5 #ifndef CHROME_BROWSER_SIGNIN_DELEGATE_ANDROID_OAUTH2_TOKEN_SERVICE_H_ |
6 #define CHROME_BROWSER_SIGNIN_ANDROID_PROFILE_OAUTH2_TOKEN_SERVICE_H_ | 6 #define CHROME_BROWSER_SIGNIN_DELEGATE_ANDROID_OAUTH2_TOKEN_SERVICE_H_ |
7 | 7 |
8 #include <jni.h> | 8 #include <jni.h> |
9 #include <string> | 9 #include <string> |
10 | 10 |
11 #include "base/android/jni_weak_ref.h" | 11 #include "base/android/jni_weak_ref.h" |
12 #include "base/callback.h" | 12 #include "base/callback.h" |
13 #include "base/memory/scoped_ptr.h" | 13 #include "base/memory/scoped_ptr.h" |
14 #include "base/time/time.h" | 14 #include "base/time/time.h" |
15 #include "components/signin/core/browser/profile_oauth2_token_service.h" | 15 #include "components/signin/core/browser/profile_oauth2_token_service.h" |
16 #include "google_apis/gaia/google_service_auth_error.h" | 16 #include "google_apis/gaia/google_service_auth_error.h" |
| 17 #include "google_apis/gaia/oauth2_token_service_delegate.h" |
17 | 18 |
18 // A specialization of ProfileOAuth2TokenService that will be returned by | 19 // A specialization of OAuth2TokenServiceDelegate that will be returned by |
19 // ProfileOAuth2TokenServiceFactory for OS_ANDROID. This instance uses | 20 // OAuth2TokenServiceDelegateFactory for OS_ANDROID. This instance uses |
20 // native Android features to lookup OAuth2 tokens. | 21 // native Android features to lookup OAuth2 tokens. |
21 // | 22 // |
22 // See |ProfileOAuth2TokenService| for usage details. | 23 // See |OAuth2TokenServiceDelegate| for usage details. |
23 // | 24 // |
24 // Note: requests should be started from the UI thread. To start a | 25 // Note: requests should be started from the UI thread. To start a |
25 // request from other thread, please use OAuth2TokenServiceRequest. | 26 // request from other thread, please use OAuth2TokenServiceRequest. |
26 class AndroidProfileOAuth2TokenService : public ProfileOAuth2TokenService { | 27 class OAuth2TokenServiceDelegateAndroid : public OAuth2TokenServiceDelegate { |
27 public: | 28 public: |
28 // Registers the AndroidProfileOAuth2TokenService's native methods through | 29 // Registers the OAuth2TokenServiceDelegateAndroid's native methods through |
29 // JNI. | 30 // JNI. |
30 static bool Register(JNIEnv* env); | 31 static bool Register(JNIEnv* env); |
31 | 32 |
32 // Creates a new instance of the AndroidProfileOAuth2TokenService. | 33 // Creates a new instance of the OAuth2TokenServiceDelegateAndroid. |
33 static AndroidProfileOAuth2TokenService* Create(); | 34 static OAuth2TokenServiceDelegateAndroid* Create(); |
34 | 35 |
35 // Returns a reference to the Java instance of this service. | 36 // Returns a reference to the Java instance of this service. |
36 static jobject GetForProfile( | 37 static jobject GetForProfile(JNIEnv* env, |
37 JNIEnv* env, jclass clazz, jobject j_profile_android); | 38 jclass clazz, |
| 39 jobject j_profile_android); |
38 | 40 |
39 // Called by the TestingProfile class to disable account validation in | 41 // Called by the TestingProfile class to disable account validation in |
40 // tests. This prevents the token service from trying to look up system | 42 // tests. This prevents the token service from trying to look up system |
41 // accounts which requires special permission. | 43 // accounts which requires special permission. |
42 static void set_is_testing_profile() { | 44 static void set_is_testing_profile() { is_testing_profile_ = true; } |
43 is_testing_profile_ = true; | |
44 } | |
45 | 45 |
46 // ProfileOAuth2TokenService overrides: | 46 void Initialize(); |
47 void Initialize(SigninClient* client, | 47 |
48 SigninErrorController* signin_error_controller) override; | 48 // OAuth2TokenServiceDelegate overrides: |
49 bool RefreshTokenIsAvailable(const std::string& account_id) const override; | 49 bool RefreshTokenIsAvailable(const std::string& account_id) const override; |
50 void UpdateAuthError(const std::string& account_id, | 50 void UpdateAuthError(const std::string& account_id, |
51 const GoogleServiceAuthError& error) override; | 51 const GoogleServiceAuthError& error) override; |
52 std::vector<std::string> GetAccounts() override; | 52 std::vector<std::string> GetAccounts() override; |
53 | 53 |
54 // Lists account at the OS level. | 54 // Lists account at the OS level. |
55 std::vector<std::string> GetSystemAccounts(); | 55 std::vector<std::string> GetSystemAccounts(); |
56 | 56 |
57 void ValidateAccounts(JNIEnv* env, | 57 void ValidateAccounts(JNIEnv* env, |
58 jobject obj, | 58 jobject obj, |
(...skipping 21 matching lines...) Expand all Loading... |
80 // Triggers a notification to all observers of the OAuth2TokenService that all | 80 // Triggers a notification to all observers of the OAuth2TokenService that all |
81 // refresh tokens have now been loaded. | 81 // refresh tokens have now been loaded. |
82 virtual void FireRefreshTokensLoadedFromJava(JNIEnv* env, jobject obj); | 82 virtual void FireRefreshTokensLoadedFromJava(JNIEnv* env, jobject obj); |
83 | 83 |
84 // Overridden from OAuth2TokenService to complete signout of all | 84 // Overridden from OAuth2TokenService to complete signout of all |
85 // OA2TService aware accounts. | 85 // OA2TService aware accounts. |
86 void RevokeAllCredentials() override; | 86 void RevokeAllCredentials() override; |
87 | 87 |
88 protected: | 88 protected: |
89 friend class ProfileOAuth2TokenServiceFactory; | 89 friend class ProfileOAuth2TokenServiceFactory; |
90 AndroidProfileOAuth2TokenService(); | 90 OAuth2TokenServiceDelegateAndroid(); |
91 ~AndroidProfileOAuth2TokenService() override; | 91 ~OAuth2TokenServiceDelegateAndroid() override; |
92 | 92 |
93 OAuth2AccessTokenFetcher* CreateAccessTokenFetcher( | 93 OAuth2AccessTokenFetcher* CreateAccessTokenFetcher( |
94 const std::string& account_id, | 94 const std::string& account_id, |
95 net::URLRequestContextGetter* getter, | 95 net::URLRequestContextGetter* getter, |
96 OAuth2AccessTokenConsumer* consumer) override; | 96 OAuth2AccessTokenConsumer* consumer) override; |
97 | 97 |
98 // Overridden from OAuth2TokenService to intercept token fetch requests and | 98 // Overridden from OAuth2TokenService to intercept token fetch requests and |
99 // redirect them to the Account Manager. | 99 // redirect them to the Account Manager. |
100 void InvalidateOAuth2Token(const std::string& account_id, | 100 void InvalidateAccessToken(const std::string& account_id, |
101 const std::string& client_id, | 101 const std::string& client_id, |
102 const ScopeSet& scopes, | 102 const OAuth2TokenService::ScopeSet& scopes, |
103 const std::string& access_token) override; | 103 const std::string& access_token) override; |
104 | 104 |
105 // Called to notify observers when a refresh token is available. | 105 // Called to notify observers when a refresh token is available. |
106 void FireRefreshTokenAvailable(const std::string& account_id) override; | 106 void FireRefreshTokenAvailable(const std::string& account_id) override; |
107 // Called to notify observers when a refresh token has been revoked. | 107 // Called to notify observers when a refresh token has been revoked. |
108 void FireRefreshTokenRevoked(const std::string& account_id) override; | 108 void FireRefreshTokenRevoked(const std::string& account_id) override; |
109 // Called to notify observers when refresh tokans have been loaded. | 109 // Called to notify observers when refresh tokans have been loaded. |
110 void FireRefreshTokensLoaded() override; | 110 void FireRefreshTokensLoaded() override; |
111 | 111 |
112 private: | 112 private: |
113 // Return whether |signed_in_account| is valid and we have access | 113 // Return whether |signed_in_account| is valid and we have access |
114 // to all the tokens in |curr_account_ids|. If |force_notifications| is true, | 114 // to all the tokens in |curr_account_ids|. If |force_notifications| is true, |
115 // TokenAvailable notifications will be sent anyway, even if the account was | 115 // TokenAvailable notifications will be sent anyway, even if the account was |
116 // already known. | 116 // already known. |
117 bool ValidateAccounts(const std::string& signed_in_account, | 117 bool ValidateAccounts(const std::string& signed_in_account, |
118 const std::vector<std::string>& prev_account_ids, | 118 const std::vector<std::string>& prev_account_ids, |
119 const std::vector<std::string>& curr_account_ids, | 119 const std::vector<std::string>& curr_account_ids, |
120 std::vector<std::string>& refreshed_ids, | 120 std::vector<std::string>& refreshed_ids, |
121 std::vector<std::string>& revoked_ids, | 121 std::vector<std::string>& revoked_ids, |
122 bool force_notifications); | 122 bool force_notifications); |
123 | 123 |
124 base::android::ScopedJavaGlobalRef<jobject> java_ref_; | 124 base::android::ScopedJavaGlobalRef<jobject> java_ref_; |
125 | 125 |
126 static bool is_testing_profile_; | 126 static bool is_testing_profile_; |
127 | 127 |
128 DISALLOW_COPY_AND_ASSIGN(AndroidProfileOAuth2TokenService); | 128 DISALLOW_COPY_AND_ASSIGN(OAuth2TokenServiceDelegateAndroid); |
129 }; | 129 }; |
130 | 130 |
131 #endif // CHROME_BROWSER_SIGNIN_ANDROID_PROFILE_OAUTH2_TOKEN_SERVICE_H_ | 131 #endif // CHROME_BROWSER_SIGNIN_DELEGATE_ANDROID_OAUTH2_TOKEN_SERVICE_H_ |
OLD | NEW |