summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--apps/DEPS4
-rw-r--r--apps/apps.gypi2
-rw-r--r--apps/shell/DEPS2
-rw-r--r--apps/shell/shell_browser_main_parts.cc5
-rw-r--r--apps/shell/shell_browser_main_parts.h2
-rw-r--r--apps/shell/shell_extensions_browser_client.cc3
-rw-r--r--apps/shell/shell_extensions_client.cc147
-rw-r--r--apps/shell/shell_extensions_client.h49
8 files changed, 208 insertions, 6 deletions
diff --git a/apps/DEPS b/apps/DEPS
index 0ffb885..db577c8 100644
--- a/apps/DEPS
+++ b/apps/DEPS
@@ -29,14 +29,12 @@ include_rules = [
"+chrome/browser/extensions/api/app_runtime/app_runtime_api.h",
"+chrome/browser/extensions/api/file_handlers/app_file_handler_util.h",
"+chrome/browser/extensions/api/file_system/file_system_api.h",
- "+chrome/browser/extensions/event_router.h",
"+chrome/browser/extensions/extension_function_dispatcher.h",
"+chrome/browser/extensions/extension_icon_image.h",
"+chrome/browser/extensions/extension_host.h",
"+chrome/browser/extensions/extension_keybinding_registry.h",
"+chrome/browser/extensions/extension_prefs.h",
"+chrome/browser/extensions/extension_prefs_factory.h",
- "+chrome/browser/extensions/extension_process_manager.h",
"+chrome/browser/extensions/extension_service.h",
"+chrome/browser/extensions/extension_system.h",
"+chrome/browser/extensions/extension_system_factory.h",
@@ -45,11 +43,9 @@ include_rules = [
"+chrome/browser/extensions/unpacked_installer.h",
"+chrome/common/extensions/api/app_runtime.h",
"+chrome/common/extensions/api/app_window.h",
- "+chrome/common/extensions/extension.h",
"+chrome/common/extensions/extension_messages.h",
"+chrome/common/extensions/extension_set.h",
"+chrome/common/extensions/manifest_handlers/icons_handler.h",
- "+chrome/common/extensions/permissions/permission_set.h",
]
specific_include_rules = {
diff --git a/apps/apps.gypi b/apps/apps.gypi
index 381c57c..be6a619 100644
--- a/apps/apps.gypi
+++ b/apps/apps.gypi
@@ -134,6 +134,8 @@
'shell/shell_content_client.h',
'shell/shell_extensions_browser_client.cc',
'shell/shell_extensions_browser_client.h',
+ 'shell/shell_extensions_client.cc',
+ 'shell/shell_extensions_client.h',
'shell/shell_main_delegate.cc',
'shell/shell_main_delegate.h',
'shell/shell_main.cc',
diff --git a/apps/shell/DEPS b/apps/shell/DEPS
index 38fd058..081a2e7 100644
--- a/apps/shell/DEPS
+++ b/apps/shell/DEPS
@@ -9,6 +9,8 @@ include_rules = [
# TODO(jamescook): Remove these. http://crbug.com/305404
# Chrome pieces for bring-up.
"+chrome/common/chrome_paths.h",
+ "+chrome/browser/extensions/extension_prefs.h",
+
# Pieces of content_shell reused in app_shell.
"+content/shell/browser/shell_browser_context.h",
]
diff --git a/apps/shell/shell_browser_main_parts.cc b/apps/shell/shell_browser_main_parts.cc
index 262c837..846d426 100644
--- a/apps/shell/shell_browser_main_parts.cc
+++ b/apps/shell/shell_browser_main_parts.cc
@@ -7,6 +7,7 @@
#include "apps/app_load_service.h"
#include "apps/shell/shell_browser_context.h"
#include "apps/shell/shell_extensions_browser_client.h"
+#include "apps/shell/shell_extensions_client.h"
#include "apps/shell/web_view_window.h"
#include "base/command_line.h"
#include "base/file_util.h"
@@ -97,7 +98,9 @@ void ShellBrowserMainParts::PreMainMessageLoopRun() {
// Initialize our "profile" equivalent.
browser_context_.reset(new ShellBrowserContext);
- // TODO(jamescook): Initialize ExtensionsClient.
+ extensions_client_.reset(new ShellExtensionsClient());
+ extensions::ExtensionsClient::Set(extensions_client_.get());
+
extensions_browser_client_.reset(
new ShellExtensionsBrowserClient(browser_context_.get()));
extensions::ExtensionsBrowserClient::Set(extensions_browser_client_.get());
diff --git a/apps/shell/shell_browser_main_parts.h b/apps/shell/shell_browser_main_parts.h
index 16f3c7a..eb17edd 100644
--- a/apps/shell/shell_browser_main_parts.h
+++ b/apps/shell/shell_browser_main_parts.h
@@ -31,6 +31,7 @@ namespace apps {
class ShellBrowserContext;
class ShellExtensionsBrowserClient;
+class ShellExtensionsClient;
// Handles initialization of AppShell.
class ShellBrowserMainParts : public content::BrowserMainParts {
@@ -60,6 +61,7 @@ class ShellBrowserMainParts : public content::BrowserMainParts {
private:
scoped_ptr<ShellBrowserContext> browser_context_;
+ scoped_ptr<ShellExtensionsClient> extensions_client_;
scoped_ptr<ShellExtensionsBrowserClient> extensions_browser_client_;
// Enable a minimal set of views::corewm to be initialized.
diff --git a/apps/shell/shell_extensions_browser_client.cc b/apps/shell/shell_extensions_browser_client.cc
index c192406..34eb29f 100644
--- a/apps/shell/shell_extensions_browser_client.cc
+++ b/apps/shell/shell_extensions_browser_client.cc
@@ -8,6 +8,7 @@
#include "base/prefs/pref_service.h"
#include "base/prefs/pref_service_factory.h"
#include "base/prefs/testing_pref_store.h"
+#include "chrome/browser/extensions/extension_prefs.h"
#include "components/user_prefs/pref_registry_syncable.h"
#include "components/user_prefs/user_prefs.h"
#include "extensions/browser/app_sorting.h"
@@ -18,7 +19,7 @@ namespace {
// See chrome::RegisterProfilePrefs() in chrome/browser/prefs/browser_prefs.cc
void RegisterPrefs(user_prefs::PrefRegistrySyncable* registry) {
- // TODO(jamescook): ExtensionPrefs::RegisterProfilePrefs(registry)
+ extensions::ExtensionPrefs::RegisterProfilePrefs(registry);
}
} // namespace
diff --git a/apps/shell/shell_extensions_client.cc b/apps/shell/shell_extensions_client.cc
new file mode 100644
index 0000000..a8fa82d
--- /dev/null
+++ b/apps/shell/shell_extensions_client.cc
@@ -0,0 +1,147 @@
+// Copyright 2013 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 "apps/shell/shell_extensions_client.h"
+
+#include "base/logging.h"
+#include "extensions/common/permissions/permission_message_provider.h"
+#include "extensions/common/permissions/permissions_provider.h"
+#include "extensions/common/url_pattern_set.h"
+
+using extensions::APIPermissionInfo;
+using extensions::APIPermissionSet;
+using extensions::Extension;
+using extensions::Manifest;
+using extensions::PermissionMessage;
+using extensions::PermissionMessages;
+using extensions::PermissionSet;
+using extensions::URLPatternSet;
+
+namespace apps {
+
+namespace {
+
+// TODO(jamescook): Refactor ChromeAPIPermissions to share some of the
+// permissions registration for app_shell. For now, allow no permissions.
+class ShellPermissionsProvider : public extensions::PermissionsProvider {
+ public:
+ ShellPermissionsProvider() {}
+ virtual ~ShellPermissionsProvider() {}
+
+ virtual std::vector<APIPermissionInfo*> GetAllPermissions() const OVERRIDE {
+ return std::vector<APIPermissionInfo*>();
+ }
+
+ virtual std::vector<AliasInfo> GetAllAliases() const OVERRIDE {
+ return std::vector<AliasInfo>();
+ }
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(ShellPermissionsProvider);
+};
+
+// TODO(jamescook): Refactor ChromePermissionsMessageProvider so we can share
+// code.
+class ShellPermissionMessageProvider
+ : public extensions::PermissionMessageProvider {
+ public:
+ ShellPermissionMessageProvider() {}
+ virtual ~ShellPermissionMessageProvider() {}
+
+ // PermissionMessageProvider implementation.
+ virtual PermissionMessages GetPermissionMessages(
+ const PermissionSet* permissions,
+ Manifest::Type extension_type) const OVERRIDE {
+ return PermissionMessages();
+ }
+
+ virtual std::vector<base::string16> GetWarningMessages(
+ const PermissionSet* permissions,
+ Manifest::Type extension_type) const OVERRIDE {
+ return std::vector<base::string16>();
+ }
+
+ virtual std::vector<base::string16> GetWarningMessagesDetails(
+ const PermissionSet* permissions,
+ Manifest::Type extension_type) const OVERRIDE {
+ return std::vector<base::string16>();
+ }
+
+ virtual bool IsPrivilegeIncrease(
+ const PermissionSet* old_permissions,
+ const PermissionSet* new_permissions,
+ Manifest::Type extension_type) const OVERRIDE {
+ // Ensure we implement this before shipping.
+ CHECK(false);
+ return false;
+ }
+
+ private:
+ DISALLOW_COPY_AND_ASSIGN(ShellPermissionMessageProvider);
+};
+
+} // namespace
+
+ShellExtensionsClient::ShellExtensionsClient() {
+}
+
+ShellExtensionsClient::~ShellExtensionsClient() {
+}
+
+void ShellExtensionsClient::Initialize() {
+ // TODO(jamescook): Do we need to whitelist any extensions?
+}
+
+const extensions::PermissionsProvider&
+ShellExtensionsClient::GetPermissionsProvider() const {
+ NOTIMPLEMENTED();
+ static ShellPermissionsProvider provider;
+ return provider;
+}
+
+const extensions::PermissionMessageProvider&
+ShellExtensionsClient::GetPermissionMessageProvider() const {
+ NOTIMPLEMENTED();
+ static ShellPermissionMessageProvider provider;
+ return provider;
+}
+
+extensions::FeatureProvider* ShellExtensionsClient::GetFeatureProviderByName(
+ const std::string& name) const {
+ NOTIMPLEMENTED();
+ return NULL;
+}
+
+void ShellExtensionsClient::FilterHostPermissions(
+ const URLPatternSet& hosts,
+ URLPatternSet* new_hosts,
+ std::set<PermissionMessage>* messages) const {
+ NOTIMPLEMENTED();
+}
+
+void ShellExtensionsClient::SetScriptingWhitelist(
+ const ScriptingWhitelist& whitelist) {
+ scripting_whitelist_ = whitelist;
+}
+
+const extensions::ExtensionsClient::ScriptingWhitelist&
+ShellExtensionsClient::GetScriptingWhitelist() const {
+ // TODO(jamescook): Real whitelist.
+ return scripting_whitelist_;
+}
+
+URLPatternSet ShellExtensionsClient::GetPermittedChromeSchemeHosts(
+ const Extension* extension,
+ const APIPermissionSet& api_permissions) const {
+ NOTIMPLEMENTED();
+ return URLPatternSet();
+}
+
+bool ShellExtensionsClient::IsScriptableURL(const GURL& url,
+ std::string* error) const {
+ NOTIMPLEMENTED();
+ return true;
+}
+
+} // namespace apps
diff --git a/apps/shell/shell_extensions_client.h b/apps/shell/shell_extensions_client.h
new file mode 100644
index 0000000..1ed3697
--- /dev/null
+++ b/apps/shell/shell_extensions_client.h
@@ -0,0 +1,49 @@
+// Copyright 2013 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 APPS_SHELL_SHELL_EXTENSIONS_CLIENT_H_
+#define APPS_SHELL_SHELL_EXTENSIONS_CLIENT_H_
+
+#include "base/basictypes.h"
+#include "base/compiler_specific.h"
+#include "extensions/common/extensions_client.h"
+
+namespace apps {
+
+// The app_shell implementation of ExtensionsClient.
+class ShellExtensionsClient : public extensions::ExtensionsClient {
+ public:
+ ShellExtensionsClient();
+ virtual ~ShellExtensionsClient();
+
+ // extensions::ExtensionsClient overrides:
+ virtual void Initialize() OVERRIDE;
+ virtual const extensions::PermissionsProvider& GetPermissionsProvider() const
+ OVERRIDE;
+ virtual const extensions::PermissionMessageProvider&
+ GetPermissionMessageProvider() const OVERRIDE;
+ virtual extensions::FeatureProvider* GetFeatureProviderByName(
+ const std::string& name) const OVERRIDE;
+ virtual void FilterHostPermissions(
+ const extensions::URLPatternSet& hosts,
+ extensions::URLPatternSet* new_hosts,
+ std::set<extensions::PermissionMessage>* messages) const OVERRIDE;
+ virtual void SetScriptingWhitelist(const ScriptingWhitelist& whitelist)
+ OVERRIDE;
+ virtual const ScriptingWhitelist& GetScriptingWhitelist() const OVERRIDE;
+ virtual extensions::URLPatternSet GetPermittedChromeSchemeHosts(
+ const extensions::Extension* extension,
+ const extensions::APIPermissionSet& api_permissions) const OVERRIDE;
+ virtual bool IsScriptableURL(const GURL& url, std::string* error) const
+ OVERRIDE;
+
+ private:
+ ScriptingWhitelist scripting_whitelist_;
+
+ DISALLOW_COPY_AND_ASSIGN(ShellExtensionsClient);
+};
+
+} // namespace apps
+
+#endif // APPS_SHELL_SHELL_EXTENSIONS_CLIENT_H_