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

Unified Diff: components/signin/ios/browser/profile_oauth2_token_service_ios.h

Issue 226643012: Upstream iOS implementation of ProfileOAuth2TokenService (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Nits Created 6 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 side-by-side diff with in-line comments
Download patch
Index: components/signin/ios/browser/profile_oauth2_token_service_ios.h
diff --git a/components/signin/ios/browser/profile_oauth2_token_service_ios.h b/components/signin/ios/browser/profile_oauth2_token_service_ios.h
new file mode 100644
index 0000000000000000000000000000000000000000..860edcf5cb62f0f26d24c94f3837ec84dcf2bfc1
--- /dev/null
+++ b/components/signin/ios/browser/profile_oauth2_token_service_ios.h
@@ -0,0 +1,163 @@
+// Copyright 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef COMPONENTS_SIGNIN_IOS_BROWSER_PROFILE_OAUTH2_TOKEN_SERVICE_IOS_H_
+#define COMPONENTS_SIGNIN_IOS_BROWSER_PROFILE_OAUTH2_TOKEN_SERVICE_IOS_H_
+
+#include <string>
+
+#include "base/threading/thread_checker.h"
+#include "components/signin/core/browser/mutable_profile_oauth2_token_service.h"
+
+class OAuth2AccessTokenFetcher;
+
+namespace ios{
+class ProfileOAuth2TokenServiceIOSProvider;
+}
+
+// A specialization of ProfileOAuth2TokenService for OS_IOS. It fetches access
+// tokens from the SSOAuth library if the user is signed in using shared
+// authentication or defaults to the parent class
+// |MutableProfileOAuth2TokenService| for pre-SSO signed in users.
+//
+// See |ProfileOAuth2TokenService| for usage details.
+class ProfileOAuth2TokenServiceIOS : public MutableProfileOAuth2TokenService {
+ public:
+ virtual ~ProfileOAuth2TokenServiceIOS();
+
+ // KeyedService
+ virtual void Shutdown() OVERRIDE;
+
+ // OAuth2TokenService
+ virtual bool RefreshTokenIsAvailable(
+ const std::string& account_id) const OVERRIDE;
+
+ virtual void InvalidateOAuth2Token(const std::string& account_id,
+ const std::string& client_id,
+ const ScopeSet& scopes,
+ const std::string& access_token) OVERRIDE;
+
+ // ProfileOAuth2TokenService
+ virtual void Initialize(SigninClient* client) OVERRIDE;
+ virtual void LoadCredentials(const std::string& primary_account_id) OVERRIDE;
+ virtual std::vector<std::string> GetAccounts() OVERRIDE;
+ virtual void UpdateAuthError(const std::string& account_id,
+ const GoogleServiceAuthError& error) OVERRIDE;
+
+ // This method should not be called when using shared authentication.
+ virtual void UpdateCredentials(const std::string& account_id,
+ const std::string& refresh_token) OVERRIDE;
+
+ // Removes all credentials from this instance of |ProfileOAuth2TokenService|,
+ // however, it does not revoke the identities from the device.
+ // Subsequent calls to |RefreshTokenIsAvailable| will return |false|.
+ virtual void RevokeAllCredentials() OVERRIDE;
+
+ // Returns the refresh token for |account_id| .
+ // Must only be called when |ShouldUseIOSSharedAuthentication| returns false.
+ std::string GetRefreshTokenWhenNotUsingSharedAuthentication(
+ const std::string& account_id);
+
+ // Reloads accounts from the provider. Fires |OnRefreshTokenAvailable| for
+ // each new account. Fires |OnRefreshTokenRevoked| for each account that was
+ // removed.
+ void ReloadCredentials();
+
+ // Upgrades to using shared authentication token service.
+ //
+ // Note: If this |ProfileOAuth2TokenServiceIOS| was using the legacy token
+ // service, then this call also revokes all tokens from the parent
+ // |MutableProfileOAuth2TokenService|.
+ void StartUsingSharedAuthentication();
+
+ // Sets |use_legacy_token_service_| to |use_legacy_token_service|.
+ //
+ // Should only be called for testing.
+ void SetUseLegacyTokenServiceForTesting(bool use_legacy_token_service);
+
+ // Revokes the OAuth2 refresh tokens for all accounts from the parent
+ // |MutableProfileOAuth2TokenService|.
+ //
+ // Note: This method should only be called if the legacy pre-SSOAuth token
+ // service is used.
+ void ForceInvalidGrantResponses();
+
+ protected:
+ friend class ProfileOAuth2TokenServiceFactory;
+
+ ProfileOAuth2TokenServiceIOS();
+
+ virtual OAuth2AccessTokenFetcher* CreateAccessTokenFetcher(
+ const std::string& account_id,
+ net::URLRequestContextGetter* getter,
+ OAuth2AccessTokenConsumer* consumer) OVERRIDE;
+
+ // Protected and virtual to be overriden by fake for testing.
+
+ // Adds |account_id| to |accounts_| if it does not exist or udpates
+ // the auth error state of |account_id| if it exists. Fires
+ // |OnRefreshTokenAvailable| if the account info is updated.
+ virtual void AddOrUpdateAccount(const std::string& account_id);
+
+ // Removes |account_id| from |accounts_|. Fires |OnRefreshTokenRevoked|
+ // if the account info is removed.
+ virtual void RemoveAccount(const std::string& account_id);
+
+ private:
+ class AccountInfo : public SigninErrorController::AuthStatusProvider {
+ public:
+ AccountInfo(ProfileOAuth2TokenService* token_service,
+ const std::string& account_id);
+ virtual ~AccountInfo();
+
+ void SetLastAuthError(const GoogleServiceAuthError& error);
+
+ // SigninErrorController::AuthStatusProvider implementation.
+ virtual std::string GetAccountId() const OVERRIDE;
+ virtual GoogleServiceAuthError GetAuthStatus() const OVERRIDE;
+
+ private:
+ ProfileOAuth2TokenService* token_service_;
+ std::string account_id_;
+ GoogleServiceAuthError last_auth_error_;
+
+ DISALLOW_COPY_AND_ASSIGN(AccountInfo);
+ };
Roger Tawa OOO till Jul 10th 2014/04/10 15:04:08 Is the only reason to duplicate this class here is
msarda 2014/04/10 15:13:36 You are pretty much true, but I think this is just
+
+ // Maps the |account_id| of accounts known to ProfileOAuth2TokenService
+ // to information about the account.
+ typedef std::map<std::string, linked_ptr<AccountInfo> > AccountInfoMap;
+
+ // MutableProfileOAuth2TokenService
+ virtual std::string GetRefreshToken(
+ const std::string& account_id) const OVERRIDE;
+
+ // Returns the iOS provider;
+ ios::ProfileOAuth2TokenServiceIOSProvider* GetProvider();
+
+ // Info about the existing accounts.
+ AccountInfoMap accounts_;
Roger Tawa OOO till Jul 10th 2014/04/10 15:04:08 Are all the following true? |accounts_| is only us
msarda 2014/04/10 15:13:36 True.
+
+ // Calls to this class are expected to be made from the browser UI thread.
+ // The purpose of this this checker is to warn us if the upstream usage of
+ // ProfileOAuth2TokenService ever gets changed to have it be used across
+ // multiple threads.
+ base::ThreadChecker thread_checker_;
+
+ // Whether to use the legacy pre-SSOAuth token service.
+ //
+ // |use_legacy_token_service_| is true iff the provider is not using shared
+ // authentication during |LoadCredentials|. Note that |LoadCredentials| is
+ // called exactly once after the PO2TS initialization iff the user is signed
+ // in.
+ //
+ // If |use_legacy_token_service_| is true, then this
+ // |ProfileOAuth2TokenServiceIOS| delegates all calls to the parent
+ // |MutableProfileOAuth2TokenService|.
+ bool use_legacy_token_service_;
+
+ DISALLOW_COPY_AND_ASSIGN(ProfileOAuth2TokenServiceIOS);
+};
+
+#endif // COMPONENTS_SIGNIN_IOS_BROWSER_PROFILE_OAUTH2_TOKEN_SERVICE_IOS_H_

Powered by Google App Engine
This is Rietveld 408576698