Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(38)

Side by Side Diff: chrome/browser/extensions/extension_system_impl.cc

Issue 288273004: A bunch of remaining parts of extension content verification (Reland) (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: fix browser test Created 6 years, 7 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « no previous file | chrome/common/extensions/extension_constants.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2014 The Chromium Authors. All rights reserved. 1 // Copyright 2014 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/extensions/extension_system_impl.h" 5 #include "chrome/browser/extensions/extension_system_impl.h"
6 6
7 #include "base/base_switches.h" 7 #include "base/base_switches.h"
8 #include "base/bind.h" 8 #include "base/bind.h"
9 #include "base/command_line.h" 9 #include "base/command_line.h"
10 #include "base/files/file_path.h" 10 #include "base/files/file_path.h"
11 #include "base/memory/weak_ptr.h" 11 #include "base/memory/weak_ptr.h"
12 #include "base/strings/string_tokenizer.h" 12 #include "base/strings/string_tokenizer.h"
13 #include "chrome/browser/browser_process.h" 13 #include "chrome/browser/browser_process.h"
14 #include "chrome/browser/content_settings/cookie_settings.h" 14 #include "chrome/browser/content_settings/cookie_settings.h"
15 #include "chrome/browser/extensions/blacklist.h" 15 #include "chrome/browser/extensions/blacklist.h"
16 #include "chrome/browser/extensions/component_loader.h" 16 #include "chrome/browser/extensions/component_loader.h"
17 #include "chrome/browser/extensions/error_console/error_console.h" 17 #include "chrome/browser/extensions/error_console/error_console.h"
18 #include "chrome/browser/extensions/extension_error_reporter.h" 18 #include "chrome/browser/extensions/extension_error_reporter.h"
19 #include "chrome/browser/extensions/extension_service.h" 19 #include "chrome/browser/extensions/extension_service.h"
20 #include "chrome/browser/extensions/extension_system_factory.h" 20 #include "chrome/browser/extensions/extension_system_factory.h"
21 #include "chrome/browser/extensions/extension_util.h" 21 #include "chrome/browser/extensions/extension_util.h"
22 #include "chrome/browser/extensions/extension_warning_badge_service.h" 22 #include "chrome/browser/extensions/extension_warning_badge_service.h"
23 #include "chrome/browser/extensions/extension_warning_set.h" 23 #include "chrome/browser/extensions/extension_warning_set.h"
24 #include "chrome/browser/extensions/install_verifier.h" 24 #include "chrome/browser/extensions/install_verifier.h"
25 #include "chrome/browser/extensions/navigation_observer.h" 25 #include "chrome/browser/extensions/navigation_observer.h"
26 #include "chrome/browser/extensions/standard_management_policy_provider.h" 26 #include "chrome/browser/extensions/standard_management_policy_provider.h"
27 #include "chrome/browser/extensions/state_store.h" 27 #include "chrome/browser/extensions/state_store.h"
28 #include "chrome/browser/extensions/unpacked_installer.h" 28 #include "chrome/browser/extensions/unpacked_installer.h"
29 #include "chrome/browser/extensions/updater/manifest_fetch_data.h"
29 #include "chrome/browser/extensions/user_script_master.h" 30 #include "chrome/browser/extensions/user_script_master.h"
30 #include "chrome/browser/profiles/profile.h" 31 #include "chrome/browser/profiles/profile.h"
31 #include "chrome/browser/profiles/profile_manager.h" 32 #include "chrome/browser/profiles/profile_manager.h"
32 #include "chrome/browser/ui/webui/extensions/extension_icon_source.h" 33 #include "chrome/browser/ui/webui/extensions/extension_icon_source.h"
33 #include "chrome/common/chrome_switches.h" 34 #include "chrome/common/chrome_switches.h"
34 #include "chrome/common/chrome_version_info.h" 35 #include "chrome/common/chrome_version_info.h"
36 #include "chrome/common/extensions/extension_file_util.h"
35 #include "chrome/common/extensions/features/feature_channel.h" 37 #include "chrome/common/extensions/features/feature_channel.h"
36 #include "chrome/common/extensions/manifest_url_handler.h" 38 #include "chrome/common/extensions/manifest_url_handler.h"
37 #include "content/public/browser/browser_thread.h" 39 #include "content/public/browser/browser_thread.h"
38 #include "content/public/browser/url_data_source.h" 40 #include "content/public/browser/url_data_source.h"
39 #include "extensions/browser/content_verifier.h" 41 #include "extensions/browser/content_verifier.h"
40 #include "extensions/browser/content_verifier_delegate.h" 42 #include "extensions/browser/content_verifier_delegate.h"
41 #include "extensions/browser/event_router.h" 43 #include "extensions/browser/event_router.h"
42 #include "extensions/browser/extension_pref_store.h" 44 #include "extensions/browser/extension_pref_store.h"
43 #include "extensions/browser/extension_pref_value_map.h" 45 #include "extensions/browser/extension_pref_value_map.h"
44 #include "extensions/browser/extension_pref_value_map_factory.h" 46 #include "extensions/browser/extension_pref_value_map_factory.h"
45 #include "extensions/browser/extension_prefs.h" 47 #include "extensions/browser/extension_prefs.h"
46 #include "extensions/browser/extension_registry.h" 48 #include "extensions/browser/extension_registry.h"
47 #include "extensions/browser/info_map.h" 49 #include "extensions/browser/info_map.h"
48 #include "extensions/browser/lazy_background_task_queue.h" 50 #include "extensions/browser/lazy_background_task_queue.h"
49 #include "extensions/browser/management_policy.h" 51 #include "extensions/browser/management_policy.h"
50 #include "extensions/browser/process_manager.h" 52 #include "extensions/browser/process_manager.h"
51 #include "extensions/browser/quota_service.h" 53 #include "extensions/browser/quota_service.h"
52 #include "extensions/browser/runtime_data.h" 54 #include "extensions/browser/runtime_data.h"
53 #include "extensions/common/constants.h" 55 #include "extensions/common/constants.h"
54 #include "extensions/common/extension.h" 56 #include "extensions/common/extension.h"
55 #include "extensions/common/manifest.h" 57 #include "extensions/common/manifest.h"
58 #include "net/base/escape.h"
56 59
57 #if defined(ENABLE_NOTIFICATIONS) 60 #if defined(ENABLE_NOTIFICATIONS)
58 #include "chrome/browser/notifications/desktop_notification_service.h" 61 #include "chrome/browser/notifications/desktop_notification_service.h"
59 #include "chrome/browser/notifications/desktop_notification_service_factory.h" 62 #include "chrome/browser/notifications/desktop_notification_service_factory.h"
60 #include "ui/message_center/notifier_settings.h" 63 #include "ui/message_center/notifier_settings.h"
61 #endif 64 #endif
62 65
63 #if defined(OS_CHROMEOS) 66 #if defined(OS_CHROMEOS)
64 #include "chrome/browser/app_mode/app_mode_utils.h" 67 #include "chrome/browser/app_mode/app_mode_utils.h"
65 #include "chrome/browser/chromeos/extensions/device_local_account_management_pol icy_provider.h" 68 #include "chrome/browser/chromeos/extensions/device_local_account_management_pol icy_provider.h"
(...skipping 78 matching lines...) Expand 10 before | Expand all | Expand 10 after
144 namespace { 147 namespace {
145 148
146 class ContentVerifierDelegateImpl : public ContentVerifierDelegate { 149 class ContentVerifierDelegateImpl : public ContentVerifierDelegate {
147 public: 150 public:
148 explicit ContentVerifierDelegateImpl(ExtensionService* service) 151 explicit ContentVerifierDelegateImpl(ExtensionService* service)
149 : service_(service->AsWeakPtr()) {} 152 : service_(service->AsWeakPtr()) {}
150 153
151 virtual ~ContentVerifierDelegateImpl() {} 154 virtual ~ContentVerifierDelegateImpl() {}
152 155
153 virtual bool ShouldBeVerified(const Extension& extension) OVERRIDE { 156 virtual bool ShouldBeVerified(const Extension& extension) OVERRIDE {
154 return ((extension.is_extension() || extension.is_legacy_packaged_app()) && 157 if (!extension.is_extension() && !extension.is_legacy_packaged_app())
155 ManifestURL::UpdatesFromGallery(&extension) && 158 return false;
156 Manifest::IsAutoUpdateableLocation(extension.location())); 159 if (!Manifest::IsAutoUpdateableLocation(extension.location()))
160 return false;
161
162 if (!ManifestURL::UpdatesFromGallery(&extension)) {
163 // It's possible that the webstore update url was overridden for testing
164 // so also consider extensions with the default (production) update url
165 // to be from the store as well.
166 GURL default_webstore_url = extension_urls::GetDefaultWebstoreUpdateUrl();
167 if (ManifestURL::GetUpdateURL(&extension) != default_webstore_url)
168 return false;
169 }
170
171 return true;
157 } 172 }
158 173
159 virtual const ContentVerifierKey& PublicKey() OVERRIDE { 174 virtual const ContentVerifierKey& PublicKey() OVERRIDE {
160 static ContentVerifierKey key( 175 static ContentVerifierKey key(
161 extension_misc::kWebstoreSignaturesPublicKey, 176 extension_misc::kWebstoreSignaturesPublicKey,
162 extension_misc::kWebstoreSignaturesPublicKeySize); 177 extension_misc::kWebstoreSignaturesPublicKeySize);
163 return key; 178 return key;
164 } 179 }
165 180
166 virtual GURL GetSignatureFetchUrl(const std::string& extension_id, 181 virtual GURL GetSignatureFetchUrl(const std::string& extension_id,
167 const base::Version& version) OVERRIDE { 182 const base::Version& version) OVERRIDE {
168 return GURL(); 183 // TODO(asargent) Factor out common code from the extension updater's
184 // ManifestFetchData class that can be shared for use here.
185 std::vector<std::string> parts;
186 parts.push_back("uc");
187 parts.push_back("installsource=signature");
188 parts.push_back("id=" + extension_id);
189 parts.push_back("v=" + version.GetString());
190 std::string x_value =
191 net::EscapeQueryParamValue(JoinString(parts, "&"), true);
192 std::string query = "response=redirect&x=" + x_value;
193
194 GURL base_url = extension_urls::GetWebstoreUpdateUrl();
195 GURL::Replacements replacements;
196 replacements.SetQuery(query.c_str(), url::Component(0, query.length()));
197 return base_url.ReplaceComponents(replacements);
198 }
199
200 virtual std::set<base::FilePath> GetBrowserImagePaths(
201 const extensions::Extension* extension) OVERRIDE {
202 return extension_file_util::GetBrowserImagePaths(extension);
169 } 203 }
170 204
171 virtual void VerifyFailed(const std::string& extension_id) OVERRIDE { 205 virtual void VerifyFailed(const std::string& extension_id) OVERRIDE {
172 if (service_) 206 if (service_)
173 service_->DisableExtension(extension_id, Extension::DISABLE_CORRUPTED); 207 service_->DisableExtension(extension_id, Extension::DISABLE_CORRUPTED);
174 } 208 }
175 209
176 private: 210 private:
177 base::WeakPtr<ExtensionService> service_; 211 base::WeakPtr<ExtensionService> service_;
178 DISALLOW_COPY_AND_ASSIGN(ContentVerifierDelegateImpl); 212 DISALLOW_COPY_AND_ASSIGN(ContentVerifierDelegateImpl);
(...skipping 312 matching lines...) Expand 10 before | Expand all | Expand 10 after
491 void ExtensionSystemImpl::UnregisterExtensionWithRequestContexts( 525 void ExtensionSystemImpl::UnregisterExtensionWithRequestContexts(
492 const std::string& extension_id, 526 const std::string& extension_id,
493 const UnloadedExtensionInfo::Reason reason) { 527 const UnloadedExtensionInfo::Reason reason) {
494 BrowserThread::PostTask( 528 BrowserThread::PostTask(
495 BrowserThread::IO, 529 BrowserThread::IO,
496 FROM_HERE, 530 FROM_HERE,
497 base::Bind(&InfoMap::RemoveExtension, info_map(), extension_id, reason)); 531 base::Bind(&InfoMap::RemoveExtension, info_map(), extension_id, reason));
498 } 532 }
499 533
500 } // namespace extensions 534 } // namespace extensions
OLDNEW
« no previous file with comments | « no previous file | chrome/common/extensions/extension_constants.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698