Index: chrome/browser/invalidation/ticl_invalidation_service.h |
diff --git a/chrome/browser/invalidation/ticl_invalidation_service.h b/chrome/browser/invalidation/ticl_invalidation_service.h |
index dde660637a1de43de899a973a643ef3f0a60fac8..1f97f4a00a1da9ea55f2c02cd9976d56bcde70d5 100644 |
--- a/chrome/browser/invalidation/ticl_invalidation_service.h |
+++ b/chrome/browser/invalidation/ticl_invalidation_service.h |
@@ -7,42 +7,50 @@ |
#include "base/memory/scoped_ptr.h" |
#include "base/threading/non_thread_safe.h" |
-#include "chrome/browser/invalidation/invalidation_frontend.h" |
+#include "base/timer.h" |
+#include "chrome/browser/invalidation/invalidation_service.h" |
#include "chrome/browser/invalidation/invalidator_storage.h" |
-#include "chrome/browser/signin/signin_global_error.h" |
+#include "chrome/browser/signin/oauth2_token_service.h" |
+#include "chrome/browser/signin/token_service.h" |
#include "components/browser_context_keyed_service/browser_context_keyed_service.h" |
#include "content/public/browser/notification_observer.h" |
#include "content/public/browser/notification_registrar.h" |
+#include "net/base/backoff_entry.h" |
#include "sync/notifier/invalidation_handler.h" |
#include "sync/notifier/invalidator_registrar.h" |
class Profile; |
class SigninManagerBase; |
-class TokenService; |
namespace syncer { |
class Invalidator; |
} |
+// TODO: Remove this dependency. See crbug.com/243482. |
+namespace extensions { |
+class PushMessagingApiTest; |
+} |
+ |
namespace invalidation { |
// This InvalidationService wraps the C++ Invalidation Client (TICL) library. |
// It provides invalidations for desktop platforms (Win, Mac, Linux). |
class TiclInvalidationService |
: public base::NonThreadSafe, |
- public BrowserContextKeyedService, |
- public InvalidationFrontend, |
+ public InvalidationService, |
public content::NotificationObserver, |
+ public OAuth2TokenService::Consumer, |
public syncer::InvalidationHandler { |
public: |
TiclInvalidationService(SigninManagerBase* signin, |
TokenService* token_service, |
+ OAuth2TokenService* oauth2_token_service, |
Profile* profile); |
virtual ~TiclInvalidationService(); |
void Init(); |
- // InvalidationFrontend implementation. |
+ // InvalidationService implementation. |
// It is an error to have registered handlers when Shutdown() is called. |
virtual void RegisterInvalidationHandler( |
syncer::InvalidationHandler* handler) OVERRIDE; |
@@ -55,13 +63,24 @@ class TiclInvalidationService |
const invalidation::ObjectId& id, |
const syncer::AckHandle& ack_handle) OVERRIDE; |
virtual syncer::InvalidatorState GetInvalidatorState() const OVERRIDE; |
- virtual std::string GetInvalidatorClientId() const; |
+ virtual std::string GetInvalidatorClientId() const OVERRIDE; |
// content::NotificationObserver implementation. |
virtual void Observe(int type, |
const content::NotificationSource& source, |
const content::NotificationDetails& details) OVERRIDE; |
+ void RequestAccessToken(); |
+ |
+ // OAuth2TokenService::Consumer implementation |
+ virtual void OnGetTokenSuccess( |
+ const OAuth2TokenService::Request* request, |
+ const std::string& access_token, |
+ const base::Time& expiration_time) OVERRIDE; |
+ virtual void OnGetTokenFailure( |
+ const OAuth2TokenService::Request* request, |
+ const GoogleServiceAuthError& error) OVERRIDE; |
+ |
// syncer::InvalidationHandler implementation. |
virtual void OnInvalidatorStateChange( |
syncer::InvalidatorState state) OVERRIDE; |
@@ -76,19 +95,21 @@ class TiclInvalidationService |
void InitForTest(syncer::Invalidator* invalidator); |
friend class TiclInvalidationServiceTestDelegate; |
+ friend class extensions::PushMessagingApiTest; |
private: |
bool IsReadyToStart(); |
bool IsStarted(); |
- void Start(); |
- void UpdateToken(); |
+ void StartInvalidator(); |
+ void UpdateInvalidatorCredentials(); |
void StopInvalidator(); |
void Logout(); |
Profile *const profile_; |
SigninManagerBase *const signin_manager_; |
TokenService *const token_service_; |
+ OAuth2TokenService *const oauth2_token_service_; |
scoped_ptr<syncer::InvalidatorRegistrar> invalidator_registrar_; |
scoped_ptr<InvalidatorStorage> invalidator_storage_; |
@@ -96,9 +117,19 @@ class TiclInvalidationService |
content::NotificationRegistrar notification_registrar_; |
+ // TiclInvalidationService needs to remember access token in order to |
+ // invalidate it with OAuth2TokenService. |
+ std::string access_token_; |
+ |
+ // TiclInvalidationService needs to hold reference to access_token_request_ |
+ // for the duration of request in order to receive callbacks. |
+ scoped_ptr<OAuth2TokenService::Request> access_token_request_; |
+ base::OneShotTimer<TiclInvalidationService> request_access_token_retry_timer_; |
+ net::BackoffEntry request_access_token_backoff_; |
+ |
DISALLOW_COPY_AND_ASSIGN(TiclInvalidationService); |
}; |
-} |
+} // namespace invalidation |
#endif // CHROME_BROWSER_INVALIDATION_TICL_INVALIDATION_SERVICE_H_ |