Upstream version 9.38.198.0
[platform/framework/web/crosswalk.git] / src / chrome / browser / extensions / chrome_extensions_browser_client.cc
index e2ba427..a118f05 100644 (file)
@@ -4,19 +4,52 @@
 
 #include "chrome/browser/extensions/chrome_extensions_browser_client.h"
 
+#include "base/command_line.h"
+#include "base/path_service.h"
+#include "base/version.h"
+#include "chrome/browser/app_mode/app_mode_utils.h"
 #include "chrome/browser/browser_process.h"
+#include "chrome/browser/extensions/activity_log/activity_log.h"
+#include "chrome/browser/extensions/api/chrome_extensions_api_client.h"
+#include "chrome/browser/extensions/api/content_settings/content_settings_service.h"
+#include "chrome/browser/extensions/api/preference/chrome_direct_setting.h"
+#include "chrome/browser/extensions/api/preference/preference_api.h"
+#include "chrome/browser/extensions/api/runtime/chrome_runtime_api_delegate.h"
+#include "chrome/browser/extensions/chrome_app_sorting.h"
+#include "chrome/browser/extensions/chrome_component_extension_resource_manager.h"
+#include "chrome/browser/extensions/chrome_extension_host_delegate.h"
+#include "chrome/browser/extensions/chrome_process_manager_delegate.h"
+#include "chrome/browser/extensions/extension_system_factory.h"
+#include "chrome/browser/extensions/extension_util.h"
+#include "chrome/browser/extensions/url_request_util.h"
+#include "chrome/browser/external_protocol/external_protocol_handler.h"
+#include "chrome/browser/net/chrome_net_log.h"
 #include "chrome/browser/profiles/profile.h"
+#include "chrome/browser/profiles/profile_manager.h"
+#include "chrome/common/chrome_paths.h"
+#include "chrome/common/chrome_switches.h"
+#include "chrome/common/chrome_version_info.h"
+#include "chrome/common/extensions/api/generated_api.h"
+#include "chrome/common/extensions/features/feature_channel.h"
+#include "chrome/common/pref_names.h"
+#include "extensions/browser/extension_function_registry.h"
+#include "extensions/browser/extension_prefs.h"
+#include "extensions/browser/pref_names.h"
+#include "extensions/common/api/generated_api.h"
 
-namespace extensions {
-
-namespace {
+#if defined(OS_CHROMEOS)
+#include "chromeos/chromeos_switches.h"
+#endif
 
-static base::LazyInstance<ChromeExtensionsBrowserClient> g_client =
-    LAZY_INSTANCE_INITIALIZER;
-
-}  // namespace
+namespace extensions {
 
-ChromeExtensionsBrowserClient::ChromeExtensionsBrowserClient() {}
+ChromeExtensionsBrowserClient::ChromeExtensionsBrowserClient() {
+  process_manager_delegate_.reset(new ChromeProcessManagerDelegate);
+  api_client_.reset(new ChromeExtensionsAPIClient);
+  // Only set if it hasn't already been set (e.g. by a test).
+  if (GetCurrentChannel() == GetDefaultChannel())
+    SetCurrentChannel(chrome::VersionInfo::GetChannel());
+}
 
 ChromeExtensionsBrowserClient::~ChromeExtensionsBrowserClient() {}
 
@@ -24,6 +57,20 @@ bool ChromeExtensionsBrowserClient::IsShuttingDown() {
   return g_browser_process->IsShuttingDown();
 }
 
+bool ChromeExtensionsBrowserClient::AreExtensionsDisabled(
+    const CommandLine& command_line,
+    content::BrowserContext* context) {
+  Profile* profile = static_cast<Profile*>(context);
+  return command_line.HasSwitch(switches::kDisableExtensions) ||
+      profile->GetPrefs()->GetBoolean(prefs::kDisableExtensions);
+}
+
+bool ChromeExtensionsBrowserClient::IsValidContext(
+    content::BrowserContext* context) {
+  Profile* profile = static_cast<Profile*>(context);
+  return g_browser_process->profile_manager()->IsValidProfile(profile);
+}
+
 bool ChromeExtensionsBrowserClient::IsSameContext(
     content::BrowserContext* first,
     content::BrowserContext* second) {
@@ -41,9 +88,174 @@ content::BrowserContext* ChromeExtensionsBrowserClient::GetOffTheRecordContext(
   return static_cast<Profile*>(context)->GetOffTheRecordProfile();
 }
 
-// static
-ChromeExtensionsBrowserClient* ChromeExtensionsBrowserClient::GetInstance() {
-  return g_client.Pointer();
+content::BrowserContext* ChromeExtensionsBrowserClient::GetOriginalContext(
+    content::BrowserContext* context) {
+  return static_cast<Profile*>(context)->GetOriginalProfile();
+}
+
+bool ChromeExtensionsBrowserClient::IsGuestSession(
+    content::BrowserContext* context) const {
+  return static_cast<Profile*>(context)->IsGuestSession();
+}
+
+bool ChromeExtensionsBrowserClient::IsExtensionIncognitoEnabled(
+    const std::string& extension_id,
+    content::BrowserContext* context) const {
+  return IsGuestSession(context)
+      || util::IsIncognitoEnabled(extension_id, context);
+}
+
+bool ChromeExtensionsBrowserClient::CanExtensionCrossIncognito(
+    const extensions::Extension* extension,
+    content::BrowserContext* context) const {
+  return IsGuestSession(context)
+      || util::CanCrossIncognito(extension, context);
+}
+
+bool ChromeExtensionsBrowserClient::IsWebViewRequest(
+    net::URLRequest* request) const {
+  return url_request_util::IsWebViewRequest(request);
+}
+
+net::URLRequestJob*
+ChromeExtensionsBrowserClient::MaybeCreateResourceBundleRequestJob(
+    net::URLRequest* request,
+    net::NetworkDelegate* network_delegate,
+    const base::FilePath& directory_path,
+    const std::string& content_security_policy,
+    bool send_cors_header) {
+  return url_request_util::MaybeCreateURLRequestResourceBundleJob(
+      request,
+      network_delegate,
+      directory_path,
+      content_security_policy,
+      send_cors_header);
+}
+
+bool ChromeExtensionsBrowserClient::AllowCrossRendererResourceLoad(
+    net::URLRequest* request,
+    bool is_incognito,
+    const Extension* extension,
+    InfoMap* extension_info_map) {
+  return url_request_util::AllowCrossRendererResourceLoad(
+      request, is_incognito, extension, extension_info_map);
+}
+
+PrefService* ChromeExtensionsBrowserClient::GetPrefServiceForContext(
+    content::BrowserContext* context) {
+  return static_cast<Profile*>(context)->GetPrefs();
+}
+
+void ChromeExtensionsBrowserClient::GetEarlyExtensionPrefsObservers(
+    content::BrowserContext* context,
+    std::vector<ExtensionPrefsObserver*>* observers) const {
+  observers->push_back(ContentSettingsService::Get(context));
+}
+
+ProcessManagerDelegate*
+ChromeExtensionsBrowserClient::GetProcessManagerDelegate() const {
+  return process_manager_delegate_.get();
+}
+
+scoped_ptr<ExtensionHostDelegate>
+ChromeExtensionsBrowserClient::CreateExtensionHostDelegate() {
+  return scoped_ptr<ExtensionHostDelegate>(new ChromeExtensionHostDelegate);
+}
+
+bool ChromeExtensionsBrowserClient::DidVersionUpdate(
+    content::BrowserContext* context) {
+  Profile* profile = static_cast<Profile*>(context);
+
+  // Unit tests may not provide prefs; assume everything is up-to-date.
+  ExtensionPrefs* extension_prefs = ExtensionPrefs::Get(profile);
+  if (!extension_prefs)
+    return false;
+
+  // If we're inside a browser test, then assume prefs are all up-to-date.
+  if (CommandLine::ForCurrentProcess()->HasSwitch(switches::kTestType))
+    return false;
+
+  PrefService* pref_service = extension_prefs->pref_service();
+  base::Version last_version;
+  if (pref_service->HasPrefPath(pref_names::kLastChromeVersion)) {
+    std::string last_version_str =
+        pref_service->GetString(pref_names::kLastChromeVersion);
+    last_version = base::Version(last_version_str);
+  }
+
+  chrome::VersionInfo current_version_info;
+  std::string current_version = current_version_info.Version();
+  pref_service->SetString(pref_names::kLastChromeVersion,
+                          current_version);
+
+  // If there was no version string in prefs, assume we're out of date.
+  if (!last_version.IsValid())
+    return true;
+
+  return last_version.IsOlderThan(current_version);
+}
+
+void ChromeExtensionsBrowserClient::PermitExternalProtocolHandler() {
+  ExternalProtocolHandler::PermitLaunchUrl();
+}
+
+scoped_ptr<AppSorting> ChromeExtensionsBrowserClient::CreateAppSorting() {
+  return scoped_ptr<AppSorting>(new ChromeAppSorting());
+}
+
+bool ChromeExtensionsBrowserClient::IsRunningInForcedAppMode() {
+  return chrome::IsRunningInForcedAppMode();
+}
+
+ApiActivityMonitor* ChromeExtensionsBrowserClient::GetApiActivityMonitor(
+    content::BrowserContext* context) {
+  // The ActivityLog monitors and records function calls and events.
+  return ActivityLog::GetInstance(context);
+}
+
+ExtensionSystemProvider*
+ChromeExtensionsBrowserClient::GetExtensionSystemFactory() {
+  return ExtensionSystemFactory::GetInstance();
+}
+
+void ChromeExtensionsBrowserClient::RegisterExtensionFunctions(
+    ExtensionFunctionRegistry* registry) const {
+  // Preferences.
+  registry->RegisterFunction<extensions::GetPreferenceFunction>();
+  registry->RegisterFunction<extensions::SetPreferenceFunction>();
+  registry->RegisterFunction<extensions::ClearPreferenceFunction>();
+
+  // Direct Preference Access for Component Extensions.
+  registry->RegisterFunction<
+      extensions::chromedirectsetting::GetDirectSettingFunction>();
+  registry->RegisterFunction<
+      extensions::chromedirectsetting::SetDirectSettingFunction>();
+  registry->RegisterFunction<
+      extensions::chromedirectsetting::ClearDirectSettingFunction>();
+
+  // Generated APIs from lower-level modules.
+  extensions::core_api::GeneratedFunctionRegistry::RegisterAll(registry);
+
+  // Generated APIs from Chrome.
+  extensions::api::GeneratedFunctionRegistry::RegisterAll(registry);
+}
+
+ComponentExtensionResourceManager*
+ChromeExtensionsBrowserClient::GetComponentExtensionResourceManager() {
+  if (!resource_manager_)
+    resource_manager_.reset(new ChromeComponentExtensionResourceManager());
+  return resource_manager_.get();
+}
+
+net::NetLog* ChromeExtensionsBrowserClient::GetNetLog() {
+  return g_browser_process->net_log();
+}
+
+scoped_ptr<extensions::RuntimeAPIDelegate>
+ChromeExtensionsBrowserClient::CreateRuntimeAPIDelegate(
+    content::BrowserContext* context) const {
+  return scoped_ptr<extensions::RuntimeAPIDelegate>(
+      new ChromeRuntimeAPIDelegate(context));
 }
 
 }  // namespace extensions