Index: chrome/browser/extensions/permissions_based_management_policy_provider.h |
diff --git a/chrome/browser/extensions/permissions_based_management_policy_provider.h b/chrome/browser/extensions/permissions_based_management_policy_provider.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..7d8fc83afb8b35e544911d0e0e29c8a0750e6c6d |
--- /dev/null |
+++ b/chrome/browser/extensions/permissions_based_management_policy_provider.h |
@@ -0,0 +1,39 @@ |
+// Copyright 2014 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_EXTENSIONS_PERMISSIONS_BASED_MANAGEMENT_POLICY_PROVIDER_H_ |
+#define CHROME_BROWSER_EXTENSIONS_PERMISSIONS_BASED_MANAGEMENT_POLICY_PROVIDER_H_ |
+ |
+#include "base/macros.h" |
+#include "extensions/browser/management_policy.h" |
+ |
+namespace extensions { |
+ |
+class Extension; |
+class ExtensionManagement; |
+ |
+// A ManagementPolicyProvider controlled by enterprise policy, and prevent |
+// certain extensions from loading by examing if its permission data conflits |
Joao da Silva
2014/10/17 12:52:39
by checking (or, by examining)
conficts
binjin
2014/10/17 14:04:23
Done.
|
+// with policy or not. |
+class PermissionsBasedManagementPolicyProvider |
+ : public ManagementPolicy::Provider { |
+ public: |
+ explicit PermissionsBasedManagementPolicyProvider( |
+ ExtensionManagement* settings); |
+ virtual ~PermissionsBasedManagementPolicyProvider(); |
+ |
+ // ManagementPolicy::Provider implementation. |
+ virtual std::string GetDebugPolicyProviderName() const override; |
+ virtual bool UserMayLoad(const Extension* extension, |
+ base::string16* error) const override; |
+ |
+ private: |
+ ExtensionManagement* settings_; |
+ |
+ DISALLOW_COPY_AND_ASSIGN(PermissionsBasedManagementPolicyProvider); |
+}; |
+ |
+} // namespace extensions |
+ |
+#endif // CHROME_BROWSER_EXTENSIONS_PERMISSIONS_BASED_MANAGEMENT_POLICY_PROVIDER_H_ |