Chromium Code Reviews| 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 |