Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/script_executor.h" | 5 #include "chrome/browser/extensions/script_executor.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | |
| 7 #include "base/callback.h" | 8 #include "base/callback.h" |
| 8 #include "base/logging.h" | 9 #include "base/logging.h" |
| 9 #include "base/pickle.h" | 10 #include "base/pickle.h" |
| 10 #include "chrome/browser/extensions/active_script_controller.h" | 11 #include "chrome/browser/extensions/active_script_controller.h" |
| 11 #include "chrome/browser/extensions/tab_helper.h" | 12 #include "chrome/browser/extensions/tab_helper.h" |
| 12 #include "content/public/browser/navigation_controller.h" | 13 #include "content/public/browser/navigation_controller.h" |
| 13 #include "content/public/browser/navigation_entry.h" | 14 #include "content/public/browser/navigation_entry.h" |
| 14 #include "content/public/browser/render_view_host.h" | 15 #include "content/public/browser/render_view_host.h" |
| 15 #include "content/public/browser/web_contents.h" | 16 #include "content/public/browser/web_contents.h" |
| 16 #include "content/public/browser/web_contents_observer.h" | 17 #include "content/public/browser/web_contents_observer.h" |
| (...skipping 102 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 119 const std::string& code, | 120 const std::string& code, |
| 120 ScriptExecutor::FrameScope frame_scope, | 121 ScriptExecutor::FrameScope frame_scope, |
| 121 UserScript::RunLocation run_at, | 122 UserScript::RunLocation run_at, |
| 122 ScriptExecutor::WorldType world_type, | 123 ScriptExecutor::WorldType world_type, |
| 123 ScriptExecutor::ProcessType process_type, | 124 ScriptExecutor::ProcessType process_type, |
| 124 const GURL& webview_src, | 125 const GURL& webview_src, |
| 125 const GURL& file_url, | 126 const GURL& file_url, |
| 126 bool user_gesture, | 127 bool user_gesture, |
| 127 ScriptExecutor::ResultType result_type, | 128 ScriptExecutor::ResultType result_type, |
| 128 const ExecuteScriptCallback& callback) { | 129 const ExecuteScriptCallback& callback) { |
| 129 ActiveScriptController* active_script_controller = | |
| 130 ActiveScriptController::GetForWebContents(web_contents_); | |
| 131 content::NavigationEntry* visible_entry = | |
| 132 web_contents_->GetController().GetVisibleEntry(); | |
| 133 if (active_script_controller && visible_entry) { | |
| 134 // TODO(rdevlin.cronin): Now, this is just a notification. Soon, it should | |
| 135 // block until the user gives the OK to execute. | |
| 136 active_script_controller->NotifyScriptExecuting(extension_id, | |
| 137 visible_entry->GetPageID()); | |
| 138 } | |
| 139 | |
| 140 ExtensionMsg_ExecuteCode_Params params; | 130 ExtensionMsg_ExecuteCode_Params params; |
| 141 params.request_id = next_request_id_++; | 131 params.request_id = next_request_id_++; |
| 142 params.extension_id = extension_id; | 132 params.extension_id = extension_id; |
| 143 params.is_javascript = (script_type == JAVASCRIPT); | 133 params.is_javascript = (script_type == JAVASCRIPT); |
| 144 params.code = code; | 134 params.code = code; |
| 145 params.all_frames = (frame_scope == ALL_FRAMES); | 135 params.all_frames = (frame_scope == ALL_FRAMES); |
| 146 params.run_at = static_cast<int>(run_at); | 136 params.run_at = static_cast<int>(run_at); |
| 147 params.in_main_world = (world_type == MAIN_WORLD); | 137 params.in_main_world = (world_type == MAIN_WORLD); |
| 148 params.is_web_view = (process_type == WEB_VIEW_PROCESS); | 138 params.is_web_view = (process_type == WEB_VIEW_PROCESS); |
| 149 params.webview_src = webview_src; | 139 params.webview_src = webview_src; |
| 150 params.file_url = file_url; | 140 params.file_url = file_url; |
| 151 params.wants_result = (result_type == JSON_SERIALIZED_RESULT); | 141 params.wants_result = (result_type == JSON_SERIALIZED_RESULT); |
| 152 params.user_gesture = user_gesture; | 142 params.user_gesture = user_gesture; |
| 153 | 143 |
| 144 ActiveScriptController* active_script_controller = | |
| 145 ActiveScriptController::GetForWebContents(web_contents_); | |
| 146 content::NavigationEntry* visible_entry = | |
| 147 web_contents_->GetController().GetVisibleEntry(); | |
| 148 if (active_script_controller && visible_entry) { | |
| 149 // The base::Unretained(this) is safe, because this and the | |
| 150 // ActiveScriptController are both attached to the TabHelper. Thus, if the | |
| 151 // ActiveScriptController is still alive to invoke the callback, this is | |
| 152 // alive, too. | |
| 153 active_script_controller->GetPermissionForInjection( | |
| 154 extension_id, | |
| 155 visible_entry->GetPageID(), | |
| 156 scoped_ptr<const base::Closure>(new base::Closure( | |
| 157 base::Bind(&ScriptExecutor::ExecuteScriptHelper, | |
| 158 base::Unretained(this), | |
| 159 params, | |
|
not at google - send to devlin
2014/05/15 00:12:36
yes, it would make sense to Pass() this.
Devlin
2014/05/15 17:45:59
Done.
| |
| 160 callback)))); | |
| 161 } else { | |
| 162 ExecuteScriptHelper(params, callback); | |
| 163 } | |
| 164 } | |
| 165 | |
| 166 void ScriptExecutor::ExecuteScriptHelper( | |
| 167 const ExtensionMsg_ExecuteCode_Params& params, | |
| 168 const ExecuteScriptCallback& callback) { | |
| 154 // Handler handles IPCs and deletes itself on completion. | 169 // Handler handles IPCs and deletes itself on completion. |
| 155 new Handler(script_observers_, web_contents_, params, callback); | 170 new Handler(script_observers_, web_contents_, params, callback); |
| 156 } | 171 } |
| 157 | 172 |
| 158 } // namespace extensions | 173 } // namespace extensions |
| OLD | NEW |