Index: chrome/browser/extensions/extension_user_script_loader.cc |
diff --git a/chrome/browser/extensions/extension_user_script_loader.cc b/chrome/browser/extensions/extension_user_script_loader.cc |
deleted file mode 100644 |
index 0104f5a20428da8cf4052c000b8a9516779a986b..0000000000000000000000000000000000000000 |
--- a/chrome/browser/extensions/extension_user_script_loader.cc |
+++ /dev/null |
@@ -1,166 +0,0 @@ |
-// Copyright 2015 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/extension_user_script_loader.h" |
- |
-#include <set> |
-#include <string> |
- |
-#include "base/bind.h" |
-#include "base/bind_helpers.h" |
-#include "base/files/file_path.h" |
-#include "base/files/file_util.h" |
-#include "base/version.h" |
-#include "chrome/browser/profiles/profile.h" |
-#include "content/public/browser/browser_thread.h" |
-#include "content/public/browser/notification_service.h" |
-#include "content/public/browser/render_process_host.h" |
-#include "extensions/browser/component_extension_resource_manager.h" |
-#include "extensions/browser/content_verifier.h" |
-#include "extensions/browser/extension_registry.h" |
-#include "extensions/browser/extension_system.h" |
-#include "extensions/browser/extensions_browser_client.h" |
-#include "extensions/common/file_util.h" |
-#include "extensions/common/manifest_handlers/default_locale_handler.h" |
-#include "extensions/common/message_bundle.h" |
-#include "extensions/common/one_shot_event.h" |
-#include "ui/base/resource/resource_bundle.h" |
- |
-namespace extensions { |
- |
-namespace { |
- |
-// Verifies file contents as they are read. |
-void VerifyContent(const scoped_refptr<ContentVerifier>& verifier, |
- const std::string& extension_id, |
- const base::FilePath& extension_root, |
- const base::FilePath& relative_path, |
- const std::string& content) { |
- DCHECK_CURRENTLY_ON(content::BrowserThread::IO); |
- scoped_refptr<ContentVerifyJob> job( |
- verifier->CreateJobFor(extension_id, extension_root, relative_path)); |
- if (job.get()) { |
- job->Start(); |
- job->BytesRead(content.size(), content.data()); |
- job->DoneReading(); |
- } |
-} |
- |
-// Loads user scripts from the extension who owns these scripts. |
-bool ExtensionLoadScriptContent( |
- const HostID& host_id, |
- UserScript::File* script_file, |
- const UserScriptLoader::SubstitutionMap* localization_messages, |
- const scoped_refptr<ContentVerifier>& verifier) { |
- DCHECK(script_file); |
- std::string content; |
- const base::FilePath& path = ExtensionResource::GetFilePath( |
- script_file->extension_root(), script_file->relative_path(), |
- ExtensionResource::SYMLINKS_MUST_RESOLVE_WITHIN_ROOT); |
- if (path.empty()) { |
- int resource_id = 0; |
- if (ExtensionsBrowserClient::Get() |
- ->GetComponentExtensionResourceManager() |
- ->IsComponentExtensionResource(script_file->extension_root(), |
- script_file->relative_path(), |
- &resource_id)) { |
- const ResourceBundle& rb = ResourceBundle::GetSharedInstance(); |
- content = rb.GetRawDataResource(resource_id).as_string(); |
- } else { |
- LOG(WARNING) << "Failed to get file path to " |
- << script_file->relative_path().value() << " from " |
- << script_file->extension_root().value(); |
- return false; |
- } |
- } else { |
- if (!base::ReadFileToString(path, &content)) { |
- LOG(WARNING) << "Failed to load user script file: " << path.value(); |
- return false; |
- } |
- if (verifier.get()) { |
- content::BrowserThread::PostTask( |
- content::BrowserThread::IO, FROM_HERE, |
- base::Bind(&VerifyContent, verifier, host_id.id(), |
- script_file->extension_root(), |
- script_file->relative_path(), content)); |
- } |
- } |
- |
- // Localize the content. |
- if (localization_messages) { |
- std::string error; |
- MessageBundle::ReplaceMessagesWithExternalDictionary(*localization_messages, |
- &content, &error); |
- if (!error.empty()) |
- LOG(WARNING) << "Failed to replace messages in script: " << error; |
- } |
- |
- // Remove BOM from the content. |
- std::string::size_type index = content.find(base::kUtf8ByteOrderMark); |
- if (index == 0) |
- script_file->set_content(content.substr(strlen(base::kUtf8ByteOrderMark))); |
- else |
- script_file->set_content(content); |
- |
- return true; |
-} |
- |
-} // namespace |
- |
-ExtensionUserScriptLoader::ExtensionUserScriptLoader( |
- Profile* profile, |
- const HostID& host_id, |
- bool listen_for_extension_system_loaded) |
- : UserScriptLoader(profile, |
- host_id, |
- ExtensionSystem::Get(profile)->content_verifier()), |
- extension_registry_observer_(this), |
- weak_factory_(this) { |
- extension_registry_observer_.Add(ExtensionRegistry::Get(profile)); |
- if (listen_for_extension_system_loaded) { |
- ExtensionSystem::Get(profile)->ready().Post( |
- FROM_HERE, |
- base::Bind(&ExtensionUserScriptLoader::OnExtensionSystemReady, |
- weak_factory_.GetWeakPtr())); |
- } else { |
- SetReady(true); |
- } |
-} |
- |
-ExtensionUserScriptLoader::~ExtensionUserScriptLoader() { |
-} |
- |
-void ExtensionUserScriptLoader::UpdateHostsInfo( |
- const std::set<HostID>& changed_hosts) { |
- ExtensionRegistry* registry = ExtensionRegistry::Get(profile()); |
- for (const HostID& host_id : changed_hosts) { |
- const Extension* extension = |
- registry->GetExtensionById(host_id.id(), ExtensionRegistry::ENABLED); |
- // |changed_hosts_| may include hosts that have been removed, |
- // which leads to the above lookup failing. In this case, just continue. |
- if (!extension) |
- continue; |
- AddHostInfo(host_id, ExtensionSet::ExtensionPathAndDefaultLocale( |
- extension->path(), |
- LocaleInfo::GetDefaultLocale(extension))); |
- } |
-} |
- |
-UserScriptLoader::LoadUserScriptsContentFunction |
-ExtensionUserScriptLoader::GetLoadUserScriptsFunction() { |
- return base::Bind(&ExtensionLoadScriptContent); |
-} |
- |
-void ExtensionUserScriptLoader::OnExtensionUnloaded( |
- content::BrowserContext* browser_context, |
- const Extension* extension, |
- UnloadedExtensionInfo::Reason reason) { |
- RemoveHostInfo(HostID(HostID::EXTENSIONS, extension->id())); |
-} |
- |
-void ExtensionUserScriptLoader::OnExtensionSystemReady() { |
- SetReady(true); |
-} |
- |
-} // namespace extensions |