summaryrefslogtreecommitdiffstats
path: root/chrome/browser/invalidation/ticl_invalidation_service.h
diff options
context:
space:
mode:
Diffstat (limited to 'chrome/browser/invalidation/ticl_invalidation_service.h')
-rw-r--r--chrome/browser/invalidation/ticl_invalidation_service.h51
1 files changed, 41 insertions, 10 deletions
diff --git a/chrome/browser/invalidation/ticl_invalidation_service.h b/chrome/browser/invalidation/ticl_invalidation_service.h
index dde6606..0a14dd8 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/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_