OLD | NEW |
---|---|
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 "extensions/renderer/user_script_injector.h" | 5 #include "extensions/renderer/user_script_injector.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/lazy_instance.h" | 9 #include "base/lazy_instance.h" |
10 #include "content/public/common/url_constants.h" | 10 #include "content/public/common/url_constants.h" |
11 #include "content/public/renderer/render_view.h" | |
11 #include "extensions/common/extension.h" | 12 #include "extensions/common/extension.h" |
12 #include "extensions/common/permissions/permissions_data.h" | 13 #include "extensions/common/permissions/permissions_data.h" |
13 #include "extensions/renderer/injection_host.h" | 14 #include "extensions/renderer/injection_host.h" |
14 #include "extensions/renderer/script_context.h" | 15 #include "extensions/renderer/script_context.h" |
15 #include "extensions/renderer/scripts_run_info.h" | 16 #include "extensions/renderer/scripts_run_info.h" |
16 #include "grit/extensions_renderer_resources.h" | 17 #include "grit/extensions_renderer_resources.h" |
17 #include "third_party/WebKit/public/web/WebDocument.h" | 18 #include "third_party/WebKit/public/web/WebDocument.h" |
18 #include "third_party/WebKit/public/web/WebFrame.h" | 19 #include "third_party/WebKit/public/web/WebFrame.h" |
19 #include "third_party/WebKit/public/web/WebScriptSource.h" | 20 #include "third_party/WebKit/public/web/WebScriptSource.h" |
20 #include "ui/base/resource/resource_bundle.h" | 21 #include "ui/base/resource/resource_bundle.h" |
(...skipping 104 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
125 PermissionsData::AccessType UserScriptInjector::CanExecuteOnFrame( | 126 PermissionsData::AccessType UserScriptInjector::CanExecuteOnFrame( |
126 const InjectionHost* injection_host, | 127 const InjectionHost* injection_host, |
127 blink::WebFrame* web_frame, | 128 blink::WebFrame* web_frame, |
128 int tab_id, | 129 int tab_id, |
129 const GURL& top_url) const { | 130 const GURL& top_url) const { |
130 // If we don't have a tab id, we have no UI surface to ask for user consent. | 131 // If we don't have a tab id, we have no UI surface to ask for user consent. |
131 // For now, we treat this as an automatic allow. | 132 // For now, we treat this as an automatic allow. |
132 if (tab_id == -1) | 133 if (tab_id == -1) |
133 return PermissionsData::ACCESS_ALLOWED; | 134 return PermissionsData::ACCESS_ALLOWED; |
134 | 135 |
136 int routing_id = content::RenderView::FromWebView(web_frame->top()->view()) | |
137 ->GetRoutingID(); | |
138 if (script_->routing_info().render_view_id == routing_id && | |
Devlin
2015/02/23 20:15:00
Should this just work with the injection host call
Xi Han
2015/02/24 16:19:55
It seems in current implementation, all webview re
Devlin
2015/02/25 17:14:38
While that's true, the reason all webview logic is
Xi Han
2015/02/27 19:36:19
As discussed offline, leave the ScriptInjector::Ca
| |
139 script_->consumer_instance_type() == | |
140 UserScript::ConsumerInstanceType::WEBVIEW) | |
141 return PermissionsData::ACCESS_ALLOWED; | |
142 | |
135 GURL effective_document_url = ScriptContext::GetEffectiveDocumentURL( | 143 GURL effective_document_url = ScriptContext::GetEffectiveDocumentURL( |
136 web_frame, web_frame->document().url(), script_->match_about_blank()); | 144 web_frame, web_frame->document().url(), script_->match_about_blank()); |
137 return injection_host->CanExecuteOnFrame( | 145 return injection_host->CanExecuteOnFrame( |
138 effective_document_url, top_url, tab_id, is_declarative_); | 146 effective_document_url, top_url, tab_id, is_declarative_); |
139 } | 147 } |
140 | 148 |
141 std::vector<blink::WebScriptSource> UserScriptInjector::GetJsSources( | 149 std::vector<blink::WebScriptSource> UserScriptInjector::GetJsSources( |
142 UserScript::RunLocation run_location) const { | 150 UserScript::RunLocation run_location) const { |
143 DCHECK_EQ(script_->run_location(), run_location); | 151 DCHECK_EQ(script_->run_location(), run_location); |
144 | 152 |
(...skipping 57 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
202 } | 210 } |
203 | 211 |
204 if (ShouldInjectCss(run_location)) | 212 if (ShouldInjectCss(run_location)) |
205 scripts_run_info->num_css += script_->css_scripts().size(); | 213 scripts_run_info->num_css += script_->css_scripts().size(); |
206 } | 214 } |
207 | 215 |
208 void UserScriptInjector::OnWillNotInject(InjectFailureReason reason) { | 216 void UserScriptInjector::OnWillNotInject(InjectFailureReason reason) { |
209 } | 217 } |
210 | 218 |
211 } // namespace extensions | 219 } // namespace extensions |
OLD | NEW |