Commit 3c52f3b7 authored by bartfab's avatar bartfab Committed by Commit bot

Switch DeviceCloudPolicyInvalidator to shared InvalidationService

The DeviceCloudPolicyInvalidator used to ensure that a suitable
InvalidationService is available on its own. This CL makes it a consumer
of AffiliatedInvalidationServiceProvider, which manages an
InvalidationService that can be shared by DeviceCloudPolicyInvalidator
and other consumers.

BUG=442800
TEST=Updated unit tests

Review URL: https://codereview.chromium.org/846453006

Cr-Commit-Position: refs/heads/master@{#313562}
parent 6600b3d9
...@@ -192,7 +192,8 @@ void BrowserPolicyConnectorChromeOS::Init( ...@@ -192,7 +192,8 @@ void BrowserPolicyConnectorChromeOS::Init(
content::BrowserThread::IO), content::BrowserThread::IO),
request_context)); request_context));
device_local_account_policy_service_->Connect(device_management_service()); device_local_account_policy_service_->Connect(device_management_service());
device_cloud_policy_invalidator_.reset(new DeviceCloudPolicyInvalidator); device_cloud_policy_invalidator_.reset(new DeviceCloudPolicyInvalidator(
affiliated_invalidation_service_provider_.get()));
SetTimezoneIfPolicyAvailable(); SetTimezoneIfPolicyAvailable();
...@@ -212,18 +213,9 @@ void BrowserPolicyConnectorChromeOS::PreShutdown() { ...@@ -212,18 +213,9 @@ void BrowserPolicyConnectorChromeOS::PreShutdown() {
// the DeviceOAuth2TokenService that is destroyed before Shutdown() is called. // the DeviceOAuth2TokenService that is destroyed before Shutdown() is called.
if (affiliated_invalidation_service_provider_) if (affiliated_invalidation_service_provider_)
affiliated_invalidation_service_provider_->Shutdown(); affiliated_invalidation_service_provider_->Shutdown();
// Let the |device_cloud_policy_invalidator_| unregister itself as an
// observer of per-Profile InvalidationServices and the device-global
// invalidation::TiclInvalidationService it may have created as an observer of
// the DeviceOAuth2TokenService that is destroyed before Shutdown() is called.
device_cloud_policy_invalidator_.reset();
} }
void BrowserPolicyConnectorChromeOS::Shutdown() { void BrowserPolicyConnectorChromeOS::Shutdown() {
// Verify that PreShutdown() has been called first.
DCHECK(!device_cloud_policy_invalidator_);
network_configuration_updater_.reset(); network_configuration_updater_.reset();
if (device_local_account_policy_service_) if (device_local_account_policy_service_)
......
...@@ -6,61 +6,38 @@ ...@@ -6,61 +6,38 @@
#define CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_CLOUD_POLICY_INVALIDATOR_H_ #define CHROME_BROWSER_CHROMEOS_POLICY_DEVICE_CLOUD_POLICY_INVALIDATOR_H_
#include "base/basictypes.h" #include "base/basictypes.h"
#include "base/compiler_specific.h"
#include "base/macros.h" #include "base/macros.h"
#include "base/memory/scoped_ptr.h" #include "base/memory/scoped_ptr.h"
#include "base/memory/scoped_vector.h" #include "chrome/browser/chromeos/policy/affiliated_invalidation_service_provider.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
namespace invalidation { namespace invalidation {
class InvalidationService; class InvalidationService;
class TiclInvalidationService;
} }
namespace policy { namespace policy {
class CloudPolicyInvalidator; class CloudPolicyInvalidator;
// This class provides invalidations for device policy via a // This class manages the lifetime of a device-global |CloudPolicyInvalidator|
// |CloudPolicyInvalidator| backed by an |InvalidationService|. If an affiliated // that handles device policy invalidations. It relies on an
// user with a connected invalidation service is logged in, that service is used // |AffiliatedInvalidationServiceProvider| to provide it with access to a shared
// to conserve server resources. If there are no logged-in users matching these // |InvalidationService| to back the |CloudPolicyInvalidator|. Whenever the
// criteria, a device-global |TiclInvalidationService| is spun up. // shared |InvalidationService| changes, the |CloudPolicyInvalidator| destroyed
// The class monitors the status of the invalidation services and switches // and re-created.
// between them whenever the service currently in use disconnects or the class DeviceCloudPolicyInvalidator
// device-global invalidation service can be replaced with another service that : public AffiliatedInvalidationServiceProvider::Consumer {
// just connected.
class DeviceCloudPolicyInvalidator : public content::NotificationObserver {
public: public:
DeviceCloudPolicyInvalidator(); explicit DeviceCloudPolicyInvalidator(
AffiliatedInvalidationServiceProvider* invalidation_service_provider);
~DeviceCloudPolicyInvalidator() override; ~DeviceCloudPolicyInvalidator() override;
// content::NotificationObserver: // AffiliatedInvalidationServiceProvider::Consumer:
void Observe(int type, void OnInvalidationServiceSet(
const content::NotificationSource& source, invalidation::InvalidationService* invalidation_service) override;
const content::NotificationDetails& details) override;
private: CloudPolicyInvalidator* GetInvalidatorForTest() const;
friend class DeviceCloudPolicyInvalidatorTest;
// Helper that monitors the status of a single |InvalidationService|.
class InvalidationServiceObserver;
// Status updates received from |InvalidationServiceObserver|s.
void OnInvalidationServiceConnected(
invalidation::InvalidationService* invalidation_service);
void OnInvalidationServiceDisconnected(
invalidation::InvalidationService* invalidation_service);
// Attempt to create a |CloudPolicyInvalidator| backed by a connected
// invalidation service. If no connected invalidation service is available for
// use, a |CloudPolicyInvalidator| will be created later when a connected
// service becomes available.
// Further ensures that a device-global invalidation service is running iff
// there is no other connected service available for use.
void TryToCreateInvalidator();
private:
// Create a |CloudPolicyInvalidator| backed by the |invalidation_service|. // Create a |CloudPolicyInvalidator| backed by the |invalidation_service|.
void CreateInvalidator( void CreateInvalidator(
invalidation::InvalidationService* invalidation_service); invalidation::InvalidationService* invalidation_service);
...@@ -68,30 +45,12 @@ class DeviceCloudPolicyInvalidator : public content::NotificationObserver { ...@@ -68,30 +45,12 @@ class DeviceCloudPolicyInvalidator : public content::NotificationObserver {
// Destroy the current |CloudPolicyInvalidator|, if any. // Destroy the current |CloudPolicyInvalidator|, if any.
void DestroyInvalidator(); void DestroyInvalidator();
// Destroy the device-global invalidation service, if any. AffiliatedInvalidationServiceProvider* invalidation_service_provider_;
void DestroyDeviceInvalidationService();
content::NotificationRegistrar registrar_;
// Device-global invalidation service.
scoped_ptr<invalidation::TiclInvalidationService>
device_invalidation_service_;
// State observer for the device-global invalidation service.
scoped_ptr<InvalidationServiceObserver> device_invalidation_service_observer_;
// State observers for logged-in users' invalidation services.
ScopedVector<InvalidationServiceObserver>
profile_invalidation_service_observers_;
// The invalidation service backing the current |CloudPolicyInvalidator|. NULL
// if no |CloudPolicyInvalidator| exists.
invalidation::InvalidationService* invalidation_service_;
// The highest invalidation version that was handled already. // The highest invalidation version that was handled already.
int64 highest_handled_invalidation_version_; int64 highest_handled_invalidation_version_;
// The current |CloudPolicyInvalidator|. NULL if no connected invalidation // The current |CloudPolicyInvalidator|. nullptr if no connected invalidation
// service is available. // service is available.
scoped_ptr<CloudPolicyInvalidator> invalidator_; scoped_ptr<CloudPolicyInvalidator> invalidator_;
......
...@@ -94,6 +94,10 @@ class CloudPolicyInvalidator : public syncer::InvalidationHandler, ...@@ -94,6 +94,10 @@ class CloudPolicyInvalidator : public syncer::InvalidationHandler,
return highest_handled_invalidation_version_; return highest_handled_invalidation_version_;
} }
invalidation::InvalidationService* invalidation_service_for_test() const {
return invalidation_service_;
}
// syncer::InvalidationHandler: // syncer::InvalidationHandler:
void OnInvalidatorStateChange(syncer::InvalidatorState state) override; void OnInvalidatorStateChange(syncer::InvalidatorState state) override;
void OnIncomingInvalidation( void OnIncomingInvalidation(
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment