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 196 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
207 | 207 |
208 service_manager::InterfaceRegistry* interface_registry = | 208 service_manager::InterfaceRegistry* interface_registry = |
209 render_frame_host->GetInterfaceRegistry(); | 209 render_frame_host->GetInterfaceRegistry(); |
210 | 210 |
211 for (const MojoService& service : mojo_services_) { | 211 for (const MojoService& service : mojo_services_) { |
212 interface_registry->AddInterface(service.service_name, | 212 interface_registry->AddInterface(service.service_name, |
213 service.service_factory, | 213 service.service_factory, |
214 browser()->BrowserMainThread()); | 214 browser()->BrowserMainThread()); |
215 } | 215 } |
216 | 216 |
| 217 browser_context_->SetFrameTreeNodeId(render_frame_host->GetProcess()->GetID(), |
| 218 render_frame_host->GetRoutingID(), |
| 219 render_frame_host->GetFrameTreeNodeId()); |
| 220 |
| 221 void RemoveFrameTreeNode(int render_process_id, int render_frame_id); |
| 222 |
217 std::string devtools_agent_host_id = | 223 std::string devtools_agent_host_id = |
218 content::DevToolsAgentHost::GetOrCreateFor(render_frame_host)->GetId(); | 224 content::DevToolsAgentHost::GetOrCreateFor(render_frame_host)->GetId(); |
219 render_frame_host_to_devtools_agent_host_id_[render_frame_host] = | 225 render_frame_host_to_devtools_agent_host_id_[render_frame_host] = |
220 devtools_agent_host_id; | 226 devtools_agent_host_id; |
221 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] = |
222 render_frame_host->GetFrameTreeNodeId(); | 228 render_frame_host->GetFrameTreeNodeId(); |
223 } | 229 } |
224 | 230 |
225 void HeadlessWebContentsImpl::RenderFrameDeleted( | 231 void HeadlessWebContentsImpl::RenderFrameDeleted( |
226 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 |
227 auto find_it = | 237 auto find_it = |
228 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); |
229 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()) |
230 return; | 240 return; |
231 | 241 |
232 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); |
233 render_frame_host_to_devtools_agent_host_id_.erase(find_it); | 243 render_frame_host_to_devtools_agent_host_id_.erase(find_it); |
234 } | 244 } |
235 | 245 |
236 bool HeadlessWebContentsImpl::GetFrameTreeNodeIdForDevToolsAgentHostId( | 246 bool HeadlessWebContentsImpl::GetFrameTreeNodeIdForDevToolsAgentHostId( |
237 const std::string& devtools_agent_host_id, | 247 const std::string& devtools_agent_host_id, |
238 int* frame_tree_node_id) const { | 248 int* frame_tree_node_id) const { |
239 const auto& find_it = | 249 const auto& find_it = |
240 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); |
241 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()) |
242 return false; | 252 return false; |
243 *frame_tree_node_id = find_it->second; | 253 *frame_tree_node_id = find_it->second; |
244 return true; | 254 return true; |
245 } | 255 } |
246 | 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::GetRenderProcessId() const { |
| 267 return web_contents()->GetRenderProcessHost()->GetID(); |
| 268 } |
| 269 |
247 bool HeadlessWebContentsImpl::OpenURL(const GURL& url) { | 270 bool HeadlessWebContentsImpl::OpenURL(const GURL& url) { |
248 if (!url.is_valid()) | 271 if (!url.is_valid()) |
249 return false; | 272 return false; |
250 content::NavigationController::LoadURLParams params(url); | 273 content::NavigationController::LoadURLParams params(url); |
251 params.transition_type = ui::PageTransitionFromInt( | 274 params.transition_type = ui::PageTransitionFromInt( |
252 ui::PAGE_TRANSITION_TYPED | ui::PAGE_TRANSITION_FROM_ADDRESS_BAR); | 275 ui::PAGE_TRANSITION_TYPED | ui::PAGE_TRANSITION_FROM_ADDRESS_BAR); |
253 web_contents_->GetController().LoadURLWithParams(params); | 276 web_contents_->GetController().LoadURLWithParams(params); |
254 web_contents_delegate_->ActivateContents(web_contents_.get()); | 277 web_contents_delegate_->ActivateContents(web_contents_.get()); |
255 web_contents_->Focus(); | 278 web_contents_->Focus(); |
256 return true; | 279 return true; |
(...skipping 119 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
376 HeadlessWebContents::Builder::MojoService::MojoService() {} | 399 HeadlessWebContents::Builder::MojoService::MojoService() {} |
377 | 400 |
378 HeadlessWebContents::Builder::MojoService::MojoService( | 401 HeadlessWebContents::Builder::MojoService::MojoService( |
379 const std::string& service_name, | 402 const std::string& service_name, |
380 const base::Callback<void(mojo::ScopedMessagePipeHandle)>& service_factory) | 403 const base::Callback<void(mojo::ScopedMessagePipeHandle)>& service_factory) |
381 : service_name(service_name), service_factory(service_factory) {} | 404 : service_name(service_name), service_factory(service_factory) {} |
382 | 405 |
383 HeadlessWebContents::Builder::MojoService::~MojoService() {} | 406 HeadlessWebContents::Builder::MojoService::~MojoService() {} |
384 | 407 |
385 } // namespace headless | 408 } // namespace headless |
OLD | NEW |