Index: chrome/browser/extensions/permissions_based_management_policy_provider.cc |
diff --git a/chrome/browser/extensions/permissions_based_management_policy_provider.cc b/chrome/browser/extensions/permissions_based_management_policy_provider.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..4b299455a30f9b7e1ab32f6bc9cf71f2ba0d2380 |
--- /dev/null |
+++ b/chrome/browser/extensions/permissions_based_management_policy_provider.cc |
@@ -0,0 +1,61 @@ |
+// 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. |
+ |
+#include "chrome/browser/extensions/permissions_based_management_policy_provider.h" |
+ |
+#include "base/strings/string16.h" |
+#include "base/strings/utf_string_conversions.h" |
+#include "chrome/browser/extensions/extension_management.h" |
+#include "extensions/common/extension.h" |
+#include "extensions/common/manifest_handlers/permissions_parser.h" |
+#include "extensions/common/permissions/permission_set.h" |
+#include "grit/extensions_strings.h" |
+#include "ui/base/l10n/l10n_util.h" |
+ |
+namespace extensions { |
+ |
+PermissionsBasedManagementPolicyProvider:: |
+ PermissionsBasedManagementPolicyProvider(ExtensionManagement* settings) |
+ : settings_(settings) { |
+} |
+ |
+PermissionsBasedManagementPolicyProvider:: |
+ ~PermissionsBasedManagementPolicyProvider() { |
+} |
+ |
+std::string |
+PermissionsBasedManagementPolicyProvider::GetDebugPolicyProviderName() const { |
+#ifdef NDEBUG |
+ NOTREACHED(); |
+ return std::string(); |
+#else |
+ return "Controlled by enterprise policy, restricting extension permissions."; |
+#endif |
+} |
+ |
+bool PermissionsBasedManagementPolicyProvider::UserMayLoad( |
+ const Extension* extension, |
+ base::string16* error) const { |
+ // Component extensions are always allowed. |
+ if (Manifest::IsComponentLocation(extension->location())) |
+ return true; |
+ |
+ scoped_refptr<const PermissionSet> required_permissions = |
+ PermissionsParser::GetRequiredPermissions(extension); |
+ |
+ if (!settings_->IsPermissionSetAllowed(extension->id(), |
+ required_permissions)) { |
+ if (error) { |
+ *error = |
+ l10n_util::GetStringFUTF16(IDS_EXTENSION_CANT_INSTALL_POLICY_BLOCKED, |
+ base::UTF8ToUTF16(extension->name()), |
+ base::UTF8ToUTF16(extension->id())); |
+ } |
+ return false; |
+ } |
+ |
+ return true; |
+} |
+ |
+} // namespace extensions |