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 |