Chromium Code Reviews| Index: components/policy/core/browser/configuration_policy_handler.h |
| diff --git a/components/policy/core/browser/configuration_policy_handler.h b/components/policy/core/browser/configuration_policy_handler.h |
| index 814f65b8f542273ccdd7a975b9afa858f833850a..ebfb18b7f7edb783ab46e9b3356fb10b6c69b985 100644 |
| --- a/components/policy/core/browser/configuration_policy_handler.h |
| +++ b/components/policy/core/browser/configuration_policy_handler.h |
| @@ -273,6 +273,40 @@ class POLICY_EXPORT SchemaValidatingPolicyHandler |
| DISALLOW_COPY_AND_ASSIGN(SchemaValidatingPolicyHandler); |
| }; |
| +// Maps policy to pref like SimplePolicyHandler while ensuring that the value |
| +// set matches the schema. |schema| is the schema used for policies, and |
| +// |strategy| is the strategy used for schema validation errors. The |
| +// |allow_recommended| and |allow_mandatory| flags indicate the levels at which |
| +// the policy can be set. A value set at an unsupported level will be ignored. |
| +class POLICY_EXPORT SimpleSchemaValidatingPolicyHandler |
| + : public SchemaValidatingPolicyHandler { |
| + public: |
| + SimpleSchemaValidatingPolicyHandler(const char* policy_name, |
|
bartfab (slow)
2014/06/11 10:08:44
This constructor is not used anywhere.
Andrew T Wilson (Slow)
2014/06/11 12:32:55
If you are going to leave this constructor in plac
kaliamoorthi
2014/06/13 13:22:27
I have removed it.
kaliamoorthi
2014/06/13 13:22:27
I have removed it.
|
| + const char* pref_path, |
| + Schema schema, |
| + SchemaOnErrorStrategy strategy); |
| + SimpleSchemaValidatingPolicyHandler(const char* policy_name, |
| + const char* pref_path, |
| + Schema schema, |
| + SchemaOnErrorStrategy strategy, |
| + bool allow_recommended, |
|
Andrew T Wilson (Slow)
2014/06/11 12:32:55
nit: I don't like passing raw bools around to cons
kaliamoorthi
2014/06/13 13:22:27
Done.
|
| + bool allow_mandatory); |
| + virtual ~SimpleSchemaValidatingPolicyHandler(); |
| + |
| + // ConfigurationPolicyHandler: |
| + virtual bool CheckPolicySettings(const PolicyMap& policies, |
| + PolicyErrorMap* errors) OVERRIDE; |
| + virtual void ApplyPolicySettings(const PolicyMap& policies, |
| + PrefValueMap* prefs) OVERRIDE; |
| + |
| + private: |
| + const char* pref_path_; |
| + const bool allow_recommended_; |
| + const bool allow_mandatory_; |
| + |
| + DISALLOW_COPY_AND_ASSIGN(SimpleSchemaValidatingPolicyHandler); |
| +}; |
| + |
| // A policy handler to deprecate multiple legacy policies with a new one. |
| // This handler will completely ignore any of legacy policy values if the new |
| // one is set. |