// Copyright (c) 2011 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 CHROME_BROWSER_POLICY_CLOUD_POLICY_SUBSYSTEM_H_ #define CHROME_BROWSER_POLICY_CLOUD_POLICY_SUBSYSTEM_H_ #pragma once #include "base/memory/scoped_ptr.h" #include "chrome/browser/prefs/pref_member.h" #include "content/common/notification_observer.h" #include "net/base/network_change_notifier.h" class PrefService; namespace net { class URLRequestContextGetter; } namespace policy { class CloudPolicyCacheBase; class CloudPolicyController; class CloudPolicyIdentityStrategy; class ConfigurationPolicyProvider; class DeviceManagementService; class DeviceTokenFetcher; class PolicyNotifier; // This class is a container for the infrastructure required to support cloud // policy. It glues together the backend, the policy controller and manages the // life cycle of the policy providers. class CloudPolicySubsystem : public NotificationObserver, public net::NetworkChangeNotifier::IPAddressObserver { public: enum PolicySubsystemState { UNENROLLED, // No enrollment attempt has been performed yet. BAD_GAIA_TOKEN, // The server rejected the GAIA auth token. UNMANAGED, // This device is unmanaged. NETWORK_ERROR, // A network error occurred, retrying makes sense. LOCAL_ERROR, // Retrying is futile. TOKEN_FETCHED, // Device has been successfully registered. SUCCESS // Policy has been fetched successfully and is in effect. }; enum ErrorDetails { NO_DETAILS, // No error, so no error details either. DMTOKEN_NETWORK_ERROR, // DeviceTokenFetcher encountered a network error. POLICY_NETWORK_ERROR, // CloudPolicyController encountered a network error. BAD_DMTOKEN, // The server rejected the DMToken. POLICY_LOCAL_ERROR, // The policy cache encountered a local error. SIGNATURE_MISMATCH, // The policy cache detected a signature mismatch. }; class Observer { public: virtual ~Observer() {} virtual void OnPolicyStateChanged(PolicySubsystemState state, ErrorDetails error_details) = 0; }; class ObserverRegistrar { public: ObserverRegistrar(CloudPolicySubsystem* cloud_policy_subsystem, CloudPolicySubsystem::Observer* observer); ~ObserverRegistrar(); private: PolicyNotifier* policy_notifier_; CloudPolicySubsystem::Observer* observer_; DISALLOW_COPY_AND_ASSIGN(ObserverRegistrar); }; CloudPolicySubsystem(CloudPolicyIdentityStrategy* identity_strategy, CloudPolicyCacheBase* policy_cache); virtual ~CloudPolicySubsystem(); // net::NetworkChangeNotifier::IPAddressObserver: virtual void OnIPAddressChanged() OVERRIDE; // Initializes the subsystem. void Initialize(PrefService* prefs, net::URLRequestContextGetter* request_context); // Shuts the subsystem down. This must be called before threading and network // infrastructure goes away. void Shutdown(); // Returns the externally visible state and corresponding error details. PolicySubsystemState state(); ErrorDetails error_details(); // Stops all auto-retrying error handling behavior inside the policy // subsystem. void StopAutoRetry(); ConfigurationPolicyProvider* GetManagedPolicyProvider(); ConfigurationPolicyProvider* GetRecommendedPolicyProvider(); // Registers cloud policy related prefs. static void RegisterPrefs(PrefService* pref_service); private: // Updates the policy controller with a new refresh rate value. void UpdatePolicyRefreshRate(); // Returns a weak pointer to this subsystem's PolicyNotifier. PolicyNotifier* notifier() { return notifier_.get(); } // NotificationObserver overrides. virtual void Observe(NotificationType type, const NotificationSource& source, const NotificationDetails& details); // The pref service that controls the refresh rate. PrefService* prefs_; // Tracks the pref value for the policy refresh rate. IntegerPrefMember policy_refresh_rate_; // Cloud policy infrastructure stuff. scoped_ptr notifier_; scoped_ptr device_management_service_; scoped_ptr device_token_fetcher_; scoped_ptr cloud_policy_cache_; scoped_ptr cloud_policy_controller_; DISALLOW_COPY_AND_ASSIGN(CloudPolicySubsystem); }; } // namespace policy #endif // CHROME_BROWSER_POLICY_CLOUD_POLICY_SUBSYSTEM_H_