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

Side by Side Diff: extensions/renderer/extension_injection_host.cc

Issue 1293673002: Create thread-safe RendererExtensionRegistry from ExtensionSet (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 4 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
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 "extensions/renderer/extension_injection_host.h" 5 #include "extensions/renderer/extension_injection_host.h"
6 6
7 #include "content/public/renderer/render_frame.h" 7 #include "content/public/renderer/render_frame.h"
8 #include "extensions/common/constants.h" 8 #include "extensions/common/constants.h"
9 #include "extensions/common/extension_set.h"
10 #include "extensions/common/manifest_handlers/csp_info.h" 9 #include "extensions/common/manifest_handlers/csp_info.h"
10 #include "extensions/renderer/renderer_extension_registry.h"
11 #include "third_party/WebKit/public/platform/WebSecurityOrigin.h" 11 #include "third_party/WebKit/public/platform/WebSecurityOrigin.h"
12 #include "third_party/WebKit/public/web/WebLocalFrame.h" 12 #include "third_party/WebKit/public/web/WebLocalFrame.h"
13 13
14 namespace extensions { 14 namespace extensions {
15 15
16 ExtensionInjectionHost::ExtensionInjectionHost( 16 ExtensionInjectionHost::ExtensionInjectionHost(
17 const Extension* extension) 17 const Extension* extension)
18 : InjectionHost(HostID(HostID::EXTENSIONS, extension->id())), 18 : InjectionHost(HostID(HostID::EXTENSIONS, extension->id())),
19 extension_(extension) { 19 extension_(extension) {
20 } 20 }
21 21
22 ExtensionInjectionHost::~ExtensionInjectionHost() { 22 ExtensionInjectionHost::~ExtensionInjectionHost() {
23 } 23 }
24 24
25 // static 25 // static
26 scoped_ptr<const InjectionHost> ExtensionInjectionHost::Create( 26 scoped_ptr<const InjectionHost> ExtensionInjectionHost::Create(
27 const std::string& extension_id, 27 const std::string& extension_id) {
28 const ExtensionSet* extensions) { 28 const Extension* extension =
29 const Extension* extension = extensions->GetByID(extension_id); 29 RendererExtensionRegistry::Get()->GetByID(extension_id);
30 if (!extension) 30 if (!extension)
31 return scoped_ptr<const ExtensionInjectionHost>(); 31 return scoped_ptr<const ExtensionInjectionHost>();
32 return scoped_ptr<const ExtensionInjectionHost>( 32 return scoped_ptr<const ExtensionInjectionHost>(
33 new ExtensionInjectionHost(extension)); 33 new ExtensionInjectionHost(extension));
34 } 34 }
35 35
36 std::string ExtensionInjectionHost::GetContentSecurityPolicy() const { 36 std::string ExtensionInjectionHost::GetContentSecurityPolicy() const {
37 return CSPInfo::GetContentSecurityPolicy(extension_); 37 return CSPInfo::GetContentSecurityPolicy(extension_);
38 } 38 }
39 39
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
85 // We notify the browser of any injection if the extension has no withheld 85 // We notify the browser of any injection if the extension has no withheld
86 // permissions (i.e., the permissions weren't restricted), but would have 86 // permissions (i.e., the permissions weren't restricted), but would have
87 // otherwise been affected by the scripts-require-action feature. 87 // otherwise been affected by the scripts-require-action feature.
88 return extension_->permissions_data()->withheld_permissions()->IsEmpty() && 88 return extension_->permissions_data()->withheld_permissions()->IsEmpty() &&
89 PermissionsData::ScriptsMayRequireActionForExtension( 89 PermissionsData::ScriptsMayRequireActionForExtension(
90 extension_, 90 extension_,
91 extension_->permissions_data()->active_permissions().get()); 91 extension_->permissions_data()->active_permissions().get());
92 } 92 }
93 93
94 } // namespace extensions 94 } // namespace extensions
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698