// 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_CONFIGURATION_POLICY_PROVIDER_H_ #define CHROME_BROWSER_POLICY_CONFIGURATION_POLICY_PROVIDER_H_ #pragma once #include <map> #include <string> #include "base/basictypes.h" #include "base/memory/scoped_ptr.h" #include "base/values.h" #include "chrome/browser/policy/configuration_policy_store_interface.h" #include "policy/configuration_policy_type.h" namespace policy { class PolicyMap; // A mostly-abstract super class for platform-specific policy providers. // Platform-specific policy providers (Windows Group Policy, gconf, // etc.) should implement a subclass of this class. class ConfigurationPolicyProvider { public: class Observer { public: virtual ~Observer() {} virtual void OnUpdatePolicy() = 0; virtual void OnProviderGoingAway() = 0; }; // Used for static arrays of policy values that is used to initialize an // instance of the ConfigurationPolicyProvider. struct PolicyDefinitionList { struct Entry { ConfigurationPolicyType policy_type; Value::ValueType value_type; const char* name; }; const Entry* begin; const Entry* end; }; explicit ConfigurationPolicyProvider(const PolicyDefinitionList* policy_list); virtual ~ConfigurationPolicyProvider(); // Must be implemented by provider subclasses to specify the provider-specific // policy decisions. The preference service invokes this |Provide| method when // it needs a policy provider to specify its policy choices. In |Provide|, the // |ConfigurationPolicyProvider| must make calls to the |Apply| method of // |store| to apply specific policies. Returns true if the policy could be // provided, otherwise false. virtual bool Provide(ConfigurationPolicyStoreInterface* store) = 0; // Check whether this provider has completed initialization. This is used to // detect whether initialization is done in case providers implementations // need to do asynchronous operations for initialization. virtual bool IsInitializationComplete() const; protected: // Decodes the value tree and writes the configuration to the given |store|. void ApplyPolicyValueTree(const DictionaryValue* policies, ConfigurationPolicyStoreInterface* store); // Writes the configuration found in the already-decoded map |policies| to // the given |store|. void ApplyPolicyMap(const PolicyMap* policies, ConfigurationPolicyStoreInterface* store); const PolicyDefinitionList* policy_definition_list() const { return policy_definition_list_; } private: friend class ConfigurationPolicyObserverRegistrar; // Temporarily needed for access to ApplyPolicyValueTree as long as we need // to support old-style policy. friend class UserPolicyCache; virtual void AddObserver(ConfigurationPolicyProvider::Observer* observer) = 0; virtual void RemoveObserver( ConfigurationPolicyProvider::Observer* observer) = 0; // Contains the default mapping from policy values to the actual names. const ConfigurationPolicyProvider::PolicyDefinitionList* policy_definition_list_; private: DISALLOW_COPY_AND_ASSIGN(ConfigurationPolicyProvider); }; // Manages observers for a ConfigurationPolicyProvider. Is used to register // observers, and automatically removes them upon destruction. // Implementation detail: to avoid duplicate bookkeeping of registered // observers, this registrar class acts as a proxy for notifications (since it // needs to register itself anyway to get OnProviderGoingAway notifications). class ConfigurationPolicyObserverRegistrar : ConfigurationPolicyProvider::Observer { public: ConfigurationPolicyObserverRegistrar(); ~ConfigurationPolicyObserverRegistrar(); void Init(ConfigurationPolicyProvider* provider, ConfigurationPolicyProvider::Observer* observer); // ConfigurationPolicyProvider::Observer implementation: virtual void OnUpdatePolicy(); virtual void OnProviderGoingAway(); private: ConfigurationPolicyProvider* provider_; ConfigurationPolicyProvider::Observer* observer_; DISALLOW_COPY_AND_ASSIGN(ConfigurationPolicyObserverRegistrar); }; } // namespace policy #endif // CHROME_BROWSER_POLICY_CONFIGURATION_POLICY_PROVIDER_H_