| OLD | NEW |
| 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 "headless/lib/browser/headless_web_contents_impl.h" | 5 #include "headless/lib/browser/headless_web_contents_impl.h" |
| 6 | 6 |
| 7 #include <string> | 7 #include <string> |
| 8 #include <utility> | 8 #include <utility> |
| 9 #include <vector> | 9 #include <vector> |
| 10 | 10 |
| (...skipping 198 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 209 | 209 |
| 210 service_manager::InterfaceRegistry* interface_registry = | 210 service_manager::InterfaceRegistry* interface_registry = |
| 211 render_frame_host->GetInterfaceRegistry(); | 211 render_frame_host->GetInterfaceRegistry(); |
| 212 | 212 |
| 213 for (const MojoService& service : mojo_services_) { | 213 for (const MojoService& service : mojo_services_) { |
| 214 interface_registry->AddInterface(service.service_name, | 214 interface_registry->AddInterface(service.service_name, |
| 215 service.service_factory, | 215 service.service_factory, |
| 216 browser()->BrowserMainThread()); | 216 browser()->BrowserMainThread()); |
| 217 } | 217 } |
| 218 | 218 |
| 219 browser_context_->SetFrameTreeNodeId(render_frame_host->GetProcess()->GetID(), |
| 220 render_frame_host->GetRoutingID(), |
| 221 render_frame_host->GetFrameTreeNodeId()); |
| 222 |
| 219 std::string devtools_agent_host_id = | 223 std::string devtools_agent_host_id = |
| 220 content::DevToolsAgentHost::GetOrCreateFor(render_frame_host)->GetId(); | 224 content::DevToolsAgentHost::GetOrCreateFor(render_frame_host)->GetId(); |
| 221 render_frame_host_to_devtools_agent_host_id_[render_frame_host] = | 225 render_frame_host_to_devtools_agent_host_id_[render_frame_host] = |
| 222 devtools_agent_host_id; | 226 devtools_agent_host_id; |
| 223 devtools_agent_id_to_frame_tree_node_id_[devtools_agent_host_id] = | 227 devtools_agent_id_to_frame_tree_node_id_[devtools_agent_host_id] = |
| 224 render_frame_host->GetFrameTreeNodeId(); | 228 render_frame_host->GetFrameTreeNodeId(); |
| 225 } | 229 } |
| 226 | 230 |
| 227 void HeadlessWebContentsImpl::RenderFrameDeleted( | 231 void HeadlessWebContentsImpl::RenderFrameDeleted( |
| 228 content::RenderFrameHost* render_frame_host) { | 232 content::RenderFrameHost* render_frame_host) { |
| 233 browser_context_->RemoveFrameTreeNode( |
| 234 render_frame_host->GetProcess()->GetID(), |
| 235 render_frame_host->GetRoutingID()); |
| 236 |
| 229 auto find_it = | 237 auto find_it = |
| 230 render_frame_host_to_devtools_agent_host_id_.find(render_frame_host); | 238 render_frame_host_to_devtools_agent_host_id_.find(render_frame_host); |
| 231 if (find_it == render_frame_host_to_devtools_agent_host_id_.end()) | 239 if (find_it == render_frame_host_to_devtools_agent_host_id_.end()) |
| 232 return; | 240 return; |
| 233 | 241 |
| 234 devtools_agent_id_to_frame_tree_node_id_.erase(find_it->second); | 242 devtools_agent_id_to_frame_tree_node_id_.erase(find_it->second); |
| 235 render_frame_host_to_devtools_agent_host_id_.erase(find_it); | 243 render_frame_host_to_devtools_agent_host_id_.erase(find_it); |
| 236 } | 244 } |
| 237 | 245 |
| 238 bool HeadlessWebContentsImpl::GetFrameTreeNodeIdForDevToolsAgentHostId( | 246 bool HeadlessWebContentsImpl::GetFrameTreeNodeIdForDevToolsAgentHostId( |
| 239 const std::string& devtools_agent_host_id, | 247 const std::string& devtools_agent_host_id, |
| 240 int* frame_tree_node_id) const { | 248 int* frame_tree_node_id) const { |
| 241 const auto& find_it = | 249 const auto& find_it = |
| 242 devtools_agent_id_to_frame_tree_node_id_.find(devtools_agent_host_id); | 250 devtools_agent_id_to_frame_tree_node_id_.find(devtools_agent_host_id); |
| 243 if (find_it == devtools_agent_id_to_frame_tree_node_id_.end()) | 251 if (find_it == devtools_agent_id_to_frame_tree_node_id_.end()) |
| 244 return false; | 252 return false; |
| 245 *frame_tree_node_id = find_it->second; | 253 *frame_tree_node_id = find_it->second; |
| 246 return true; | 254 return true; |
| 247 } | 255 } |
| 248 | 256 |
| 257 std::string |
| 258 HeadlessWebContentsImpl::GetUntrustedDevToolsFrameIdForFrameTreeNodeId( |
| 259 int process_id, |
| 260 int frame_tree_node_id) const { |
| 261 return content::DevToolsAgentHost:: |
| 262 GetUntrustedDevToolsFrameIdForFrameTreeNodeId(process_id, |
| 263 frame_tree_node_id); |
| 264 } |
| 265 |
| 266 int HeadlessWebContentsImpl::GetMainFrameRenderProcessId() const { |
| 267 return web_contents()->GetRenderProcessHost()->GetID(); |
| 268 } |
| 269 |
| 249 bool HeadlessWebContentsImpl::OpenURL(const GURL& url) { | 270 bool HeadlessWebContentsImpl::OpenURL(const GURL& url) { |
| 250 if (!url.is_valid()) | 271 if (!url.is_valid()) |
| 251 return false; | 272 return false; |
| 252 content::NavigationController::LoadURLParams params(url); | 273 content::NavigationController::LoadURLParams params(url); |
| 253 params.transition_type = ui::PageTransitionFromInt( | 274 params.transition_type = ui::PageTransitionFromInt( |
| 254 ui::PAGE_TRANSITION_TYPED | ui::PAGE_TRANSITION_FROM_ADDRESS_BAR); | 275 ui::PAGE_TRANSITION_TYPED | ui::PAGE_TRANSITION_FROM_ADDRESS_BAR); |
| 255 web_contents_->GetController().LoadURLWithParams(params); | 276 web_contents_->GetController().LoadURLWithParams(params); |
| 256 web_contents_delegate_->ActivateContents(web_contents_.get()); | 277 web_contents_delegate_->ActivateContents(web_contents_.get()); |
| 257 web_contents_->Focus(); | 278 web_contents_->Focus(); |
| 258 return true; | 279 return true; |
| (...skipping 133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 392 HeadlessWebContents::Builder::MojoService::MojoService() {} | 413 HeadlessWebContents::Builder::MojoService::MojoService() {} |
| 393 | 414 |
| 394 HeadlessWebContents::Builder::MojoService::MojoService( | 415 HeadlessWebContents::Builder::MojoService::MojoService( |
| 395 const std::string& service_name, | 416 const std::string& service_name, |
| 396 const base::Callback<void(mojo::ScopedMessagePipeHandle)>& service_factory) | 417 const base::Callback<void(mojo::ScopedMessagePipeHandle)>& service_factory) |
| 397 : service_name(service_name), service_factory(service_factory) {} | 418 : service_name(service_name), service_factory(service_factory) {} |
| 398 | 419 |
| 399 HeadlessWebContents::Builder::MojoService::~MojoService() {} | 420 HeadlessWebContents::Builder::MojoService::~MojoService() {} |
| 400 | 421 |
| 401 } // namespace headless | 422 } // namespace headless |
| OLD | NEW |