| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "content/browser/frame_host/render_frame_host_manager.h" | 5 #include "content/browser/frame_host/render_frame_host_manager.h" |
| 6 | 6 |
| 7 #include <utility> | 7 #include <utility> |
| 8 | 8 |
| 9 #include "base/command_line.h" | 9 #include "base/command_line.h" |
| 10 #include "base/debug/trace_event.h" | 10 #include "base/debug/trace_event.h" |
| (...skipping 12 matching lines...) Expand all Loading... |
| 23 #include "content/browser/frame_host/navigator.h" | 23 #include "content/browser/frame_host/navigator.h" |
| 24 #include "content/browser/frame_host/render_frame_host_factory.h" | 24 #include "content/browser/frame_host/render_frame_host_factory.h" |
| 25 #include "content/browser/frame_host/render_frame_host_impl.h" | 25 #include "content/browser/frame_host/render_frame_host_impl.h" |
| 26 #include "content/browser/frame_host/render_frame_proxy_host.h" | 26 #include "content/browser/frame_host/render_frame_proxy_host.h" |
| 27 #include "content/browser/renderer_host/render_process_host_impl.h" | 27 #include "content/browser/renderer_host/render_process_host_impl.h" |
| 28 #include "content/browser/renderer_host/render_view_host_factory.h" | 28 #include "content/browser/renderer_host/render_view_host_factory.h" |
| 29 #include "content/browser/renderer_host/render_view_host_impl.h" | 29 #include "content/browser/renderer_host/render_view_host_impl.h" |
| 30 #include "content/browser/site_instance_impl.h" | 30 #include "content/browser/site_instance_impl.h" |
| 31 #include "content/browser/webui/web_ui_controller_factory_registry.h" | 31 #include "content/browser/webui/web_ui_controller_factory_registry.h" |
| 32 #include "content/browser/webui/web_ui_impl.h" | 32 #include "content/browser/webui/web_ui_impl.h" |
| 33 #include "content/common/navigation_params.h" |
| 33 #include "content/common/view_messages.h" | 34 #include "content/common/view_messages.h" |
| 34 #include "content/public/browser/content_browser_client.h" | 35 #include "content/public/browser/content_browser_client.h" |
| 35 #include "content/public/browser/notification_service.h" | 36 #include "content/public/browser/notification_service.h" |
| 36 #include "content/public/browser/notification_types.h" | 37 #include "content/public/browser/notification_types.h" |
| 37 #include "content/public/browser/render_widget_host_iterator.h" | 38 #include "content/public/browser/render_widget_host_iterator.h" |
| 38 #include "content/public/browser/render_widget_host_view.h" | 39 #include "content/public/browser/render_widget_host_view.h" |
| 39 #include "content/public/browser/user_metrics.h" | 40 #include "content/public/browser/user_metrics.h" |
| 40 #include "content/public/browser/web_ui_controller.h" | 41 #include "content/public/browser/web_ui_controller.h" |
| 41 #include "content/public/common/content_switches.h" | 42 #include "content/public/common/content_switches.h" |
| 42 #include "content/public/common/referrer.h" | 43 #include "content/public/common/referrer.h" |
| 43 #include "content/public/common/url_constants.h" | 44 #include "content/public/common/url_constants.h" |
| 44 #include "net/base/load_flags.h" | 45 #include "net/base/load_flags.h" |
| 45 | 46 |
| 46 namespace content { | 47 namespace content { |
| 47 | 48 |
| 48 namespace { | 49 // PlzNavigate |
| 50 // Returns the net load flags to use based on the navigation type. |
| 51 // TODO(clamy): unify the code with what is happening on the renderer side. |
| 52 int LoadFlagFromNavigationType(FrameMsg_Navigate_Type::Value navigation_type) { |
| 53 int load_flags = net::LOAD_NORMAL; |
| 54 switch (navigation_type) { |
| 55 case FrameMsg_Navigate_Type::RELOAD: |
| 56 case FrameMsg_Navigate_Type::RELOAD_ORIGINAL_REQUEST_URL: |
| 57 load_flags |= net::LOAD_VALIDATE_CACHE; |
| 58 break; |
| 59 case FrameMsg_Navigate_Type::RELOAD_IGNORING_CACHE: |
| 60 load_flags |= net::LOAD_BYPASS_CACHE; |
| 61 break; |
| 62 case FrameMsg_Navigate_Type::RESTORE: |
| 63 load_flags |= net::LOAD_PREFERRING_CACHE; |
| 64 break; |
| 65 case FrameMsg_Navigate_Type::RESTORE_WITH_POST: |
| 66 load_flags |= net::LOAD_ONLY_FROM_CACHE; |
| 67 break; |
| 68 case FrameMsg_Navigate_Type::NORMAL: |
| 69 default: |
| 70 break; |
| 71 } |
| 72 return load_flags; |
| 73 } |
| 49 | 74 |
| 50 // PlzNavigate | 75 // PlzNavigate |
| 51 // Simulates a renderer response to a navigation request when there is no live | 76 // Generates a default FrameHostMsg_BeginNavigation_Params to be used when there |
| 52 // renderer. | 77 // is no live renderer. |
| 53 FrameHostMsg_BeginNavigation_Params BeginNavigationFromNavigate( | 78 FrameHostMsg_BeginNavigation_Params MakeDefaultBeginNavigation( |
| 54 const FrameMsg_Navigate_Params& navigate_params) { | 79 const RequestNavigationParams& request_params, |
| 80 FrameMsg_Navigate_Type::Value navigation_type) { |
| 55 FrameHostMsg_BeginNavigation_Params begin_navigation_params; | 81 FrameHostMsg_BeginNavigation_Params begin_navigation_params; |
| 56 begin_navigation_params.method = navigate_params.is_post ? "POST" : "GET"; | 82 begin_navigation_params.method = request_params.is_post ? "POST" : "GET"; |
| 57 begin_navigation_params.url = navigate_params.url; | 83 begin_navigation_params.load_flags = |
| 58 begin_navigation_params.referrer = | 84 LoadFlagFromNavigationType(navigation_type); |
| 59 Referrer(navigate_params.referrer.url, navigate_params.referrer.policy); | |
| 60 | |
| 61 // TODO(clamy): This should be modified to take into account caching policy | |
| 62 // requirements (eg for POST reloads). | |
| 63 begin_navigation_params.load_flags = net::LOAD_NORMAL; | |
| 64 | 85 |
| 65 // TODO(clamy): Post data from the browser should be put in the request body. | 86 // TODO(clamy): Post data from the browser should be put in the request body. |
| 87 // Headers should be filled in as well. |
| 66 | 88 |
| 67 begin_navigation_params.has_user_gesture = false; | 89 begin_navigation_params.has_user_gesture = false; |
| 68 begin_navigation_params.transition_type = navigate_params.transition; | |
| 69 begin_navigation_params.should_replace_current_entry = | |
| 70 navigate_params.should_replace_current_entry; | |
| 71 begin_navigation_params.allow_download = | |
| 72 navigate_params.allow_download; | |
| 73 return begin_navigation_params; | 90 return begin_navigation_params; |
| 74 } | 91 } |
| 75 | 92 |
| 76 } // namespace | |
| 77 | |
| 78 bool RenderFrameHostManager::ClearRFHsPendingShutdown(FrameTreeNode* node) { | 93 bool RenderFrameHostManager::ClearRFHsPendingShutdown(FrameTreeNode* node) { |
| 79 node->render_manager()->pending_delete_hosts_.clear(); | 94 node->render_manager()->pending_delete_hosts_.clear(); |
| 80 return true; | 95 return true; |
| 81 } | 96 } |
| 82 | 97 |
| 83 RenderFrameHostManager::RenderFrameHostManager( | 98 RenderFrameHostManager::RenderFrameHostManager( |
| 84 FrameTreeNode* frame_tree_node, | 99 FrameTreeNode* frame_tree_node, |
| 85 RenderFrameHostDelegate* render_frame_delegate, | 100 RenderFrameHostDelegate* render_frame_delegate, |
| 86 RenderViewHostDelegate* render_view_delegate, | 101 RenderViewHostDelegate* render_view_delegate, |
| 87 RenderWidgetHostDelegate* render_widget_delegate, | 102 RenderWidgetHostDelegate* render_widget_delegate, |
| (...skipping 471 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 559 if (iter != pending_delete_hosts_.end() && iter->second.get() == rfh) | 574 if (iter != pending_delete_hosts_.end() && iter->second.get() == rfh) |
| 560 pending_delete_hosts_.erase(site_instance_id); | 575 pending_delete_hosts_.erase(site_instance_id); |
| 561 } | 576 } |
| 562 | 577 |
| 563 void RenderFrameHostManager::ResetProxyHosts() { | 578 void RenderFrameHostManager::ResetProxyHosts() { |
| 564 STLDeleteValues(&proxy_hosts_); | 579 STLDeleteValues(&proxy_hosts_); |
| 565 } | 580 } |
| 566 | 581 |
| 567 // PlzNavigate | 582 // PlzNavigate |
| 568 bool RenderFrameHostManager::RequestNavigation( | 583 bool RenderFrameHostManager::RequestNavigation( |
| 569 const NavigationEntryImpl& entry, | 584 scoped_ptr<NavigationRequest> navigation_request, |
| 570 const FrameMsg_Navigate_Params& navigate_params) { | 585 const RequestNavigationParams& request_params) { |
| 571 CHECK(CommandLine::ForCurrentProcess()->HasSwitch( | 586 CHECK(CommandLine::ForCurrentProcess()->HasSwitch( |
| 572 switches::kEnableBrowserSideNavigation)); | 587 switches::kEnableBrowserSideNavigation)); |
| 588 |
| 589 // TODO(clamy): Check if navigations are blocked and if so store the |
| 590 // parameters. |
| 591 |
| 592 // If there is an ongoing request it must be canceled. |
| 593 if (navigation_request_.get()) |
| 594 navigation_request_->CancelNavigation(); |
| 595 |
| 596 navigation_request_ = navigation_request.Pass(); |
| 597 |
| 573 if (render_frame_host_->IsRenderFrameLive()) { | 598 if (render_frame_host_->IsRenderFrameLive()) { |
| 574 // TODO(clamy): send a RequestNavigation IPC. | 599 // TODO(clamy): send a RequestNavigation IPC. |
| 575 return true; | 600 return true; |
| 576 } | 601 } |
| 577 | 602 |
| 578 // The navigation request is sent directly to the IO thread. | 603 // The navigation request is sent directly to the IO thread. |
| 579 OnBeginNavigation(BeginNavigationFromNavigate(navigate_params)); | 604 OnBeginNavigation( |
| 605 MakeDefaultBeginNavigation( |
| 606 request_params, navigation_request_->common_params().navigation_type), |
| 607 navigation_request_->common_params()); |
| 580 return true; | 608 return true; |
| 581 } | 609 } |
| 582 | 610 |
| 583 // PlzNavigate | 611 // PlzNavigate |
| 584 void RenderFrameHostManager::OnBeginNavigation( | 612 void RenderFrameHostManager::OnBeginNavigation( |
| 585 const FrameHostMsg_BeginNavigation_Params& params) { | 613 const FrameHostMsg_BeginNavigation_Params& params, |
| 614 const CommonNavigationParams& common_params) { |
| 586 CHECK(CommandLine::ForCurrentProcess()->HasSwitch( | 615 CHECK(CommandLine::ForCurrentProcess()->HasSwitch( |
| 587 switches::kEnableBrowserSideNavigation)); | 616 switches::kEnableBrowserSideNavigation)); |
| 588 // TODO(clamy): Check if navigations are blocked and if so, return | 617 // TODO(clamy): In case of a renderer initiated navigation create a new |
| 589 // immediately. | 618 // NavigationRequest. |
| 590 NavigationRequestInfo info(params); | 619 DCHECK(navigation_request_.get()); |
| 620 // Update the referrer with the one received from the renderer. |
| 621 navigation_request_->common_params().referrer = common_params.referrer; |
| 591 | 622 |
| 592 info.first_party_for_cookies = frame_tree_node_->IsMainFrame() ? | 623 scoped_ptr<NavigationRequestInfo> info(new NavigationRequestInfo(params)); |
| 593 params.url : frame_tree_node_->frame_tree()->root()->current_url(); | 624 |
| 594 info.is_main_frame = frame_tree_node_->IsMainFrame(); | 625 info->first_party_for_cookies = |
| 595 info.parent_is_main_frame = !frame_tree_node_->parent() ? | 626 frame_tree_node_->IsMainFrame() |
| 627 ? navigation_request_->common_params().url |
| 628 : frame_tree_node_->frame_tree()->root()->current_url(); |
| 629 info->is_main_frame = frame_tree_node_->IsMainFrame(); |
| 630 info->parent_is_main_frame = !frame_tree_node_->parent() ? |
| 596 false : frame_tree_node_->parent()->IsMainFrame(); | 631 false : frame_tree_node_->parent()->IsMainFrame(); |
| 597 | 632 |
| 598 // TODO(clamy): Check if the current RFH should be initialized (in case it has | 633 // TODO(clamy): Check if the current RFH should be initialized (in case it has |
| 599 // crashed) not to display a sad tab while navigating. | 634 // crashed) not to display a sad tab while navigating. |
| 600 // TODO(clamy): Spawn a speculative renderer process if we do not have one to | 635 // TODO(clamy): Spawn a speculative renderer process if we do not have one to |
| 601 // use for the navigation. | 636 // use for the navigation. |
| 602 | 637 |
| 603 // If there is an ongoing request it must be canceled. | 638 navigation_request_->BeginNavigation(info.Pass(), params.request_body); |
| 604 if (navigation_request_.get()) | |
| 605 navigation_request_->CancelNavigation(); | |
| 606 | |
| 607 navigation_request_.reset(new NavigationRequest( | |
| 608 info, frame_tree_node_->frame_tree_node_id())); | |
| 609 navigation_request_->BeginNavigation(params.request_body); | |
| 610 } | 639 } |
| 611 | 640 |
| 612 // PlzNavigate | 641 // PlzNavigate |
| 613 void RenderFrameHostManager::CommitNavigation( | 642 void RenderFrameHostManager::CommitNavigation( |
| 614 const NavigationBeforeCommitInfo& info) { | 643 const NavigationBeforeCommitInfo& info) { |
| 615 CHECK(CommandLine::ForCurrentProcess()->HasSwitch( | 644 CHECK(CommandLine::ForCurrentProcess()->HasSwitch( |
| 616 switches::kEnableBrowserSideNavigation)); | 645 switches::kEnableBrowserSideNavigation)); |
| 617 DCHECK(navigation_request_.get()); | 646 DCHECK(navigation_request_.get()); |
| 618 // Ignores navigation commits if the request ID doesn't match the current | 647 // Ignores navigation commits if the request ID doesn't match the current |
| 619 // active request. | 648 // active request. |
| 620 if (navigation_request_->navigation_request_id() != | 649 if (navigation_request_->navigation_request_id() != |
| 621 info.navigation_request_id) { | 650 info.navigation_request_id) { |
| 622 return; | 651 return; |
| 623 } | 652 } |
| 624 | 653 |
| 625 // Pick the right RenderFrameHost to commit the navigation. | 654 // Pick the right RenderFrameHost to commit the navigation. |
| 626 SiteInstance* current_instance = render_frame_host_->GetSiteInstance(); | 655 SiteInstance* current_instance = render_frame_host_->GetSiteInstance(); |
| 627 // TODO(clamy): Replace the default values by the right ones. This may require | 656 // TODO(clamy): Replace the default values by the right ones. This may require |
| 628 // some storing in RequestNavigation. | 657 // some storing in RequestNavigation. |
| 629 scoped_refptr<SiteInstance> new_instance = GetSiteInstanceForNavigation( | 658 scoped_refptr<SiteInstance> new_instance = GetSiteInstanceForNavigation( |
| 630 info.navigation_url, | 659 info.navigation_url, |
| 631 NULL, | 660 NULL, |
| 632 navigation_request_->info().navigation_params.transition_type, | 661 navigation_request_->common_params().transition, |
| 633 false, | 662 false, |
| 634 false); | 663 false); |
| 635 DCHECK(!pending_render_frame_host_.get()); | 664 DCHECK(!pending_render_frame_host_.get()); |
| 636 | 665 |
| 637 // TODO(clamy): Update how pending WebUI objects are handled. | 666 // TODO(clamy): Update how pending WebUI objects are handled. |
| 638 if (current_instance != new_instance.get()) { | 667 if (current_instance != new_instance.get()) { |
| 639 CreateRenderFrameHostForNewSiteInstance( | 668 CreateRenderFrameHostForNewSiteInstance( |
| 640 current_instance, new_instance.get(), frame_tree_node_->IsMainFrame()); | 669 current_instance, new_instance.get(), frame_tree_node_->IsMainFrame()); |
| 641 DCHECK(pending_render_frame_host_.get()); | 670 DCHECK(pending_render_frame_host_.get()); |
| 642 // TODO(clamy): Wait until the navigation has committed before swapping | 671 // TODO(clamy): Wait until the navigation has committed before swapping |
| (...skipping 12 matching lines...) Expand all Loading... |
| 655 render_frame_host_->GetSiteInstance()); | 684 render_frame_host_->GetSiteInstance()); |
| 656 if (!InitRenderView(render_frame_host_->render_view_host(), | 685 if (!InitRenderView(render_frame_host_->render_view_host(), |
| 657 opener_route_id, | 686 opener_route_id, |
| 658 MSG_ROUTING_NONE, | 687 MSG_ROUTING_NONE, |
| 659 frame_tree_node_->IsMainFrame())) { | 688 frame_tree_node_->IsMainFrame())) { |
| 660 return; | 689 return; |
| 661 } | 690 } |
| 662 } | 691 } |
| 663 | 692 |
| 664 frame_tree_node_->navigator()->CommitNavigation( | 693 frame_tree_node_->navigator()->CommitNavigation( |
| 665 render_frame_host_.get(), info); | 694 render_frame_host_.get(), |
| 695 info.stream_url, |
| 696 navigation_request_->common_params(), |
| 697 navigation_request_->commit_params()); |
| 666 } | 698 } |
| 667 | 699 |
| 668 void RenderFrameHostManager::Observe( | 700 void RenderFrameHostManager::Observe( |
| 669 int type, | 701 int type, |
| 670 const NotificationSource& source, | 702 const NotificationSource& source, |
| 671 const NotificationDetails& details) { | 703 const NotificationDetails& details) { |
| 672 switch (type) { | 704 switch (type) { |
| 673 case NOTIFICATION_RENDERER_PROCESS_CLOSED: | 705 case NOTIFICATION_RENDERER_PROCESS_CLOSED: |
| 674 case NOTIFICATION_RENDERER_PROCESS_CLOSING: | 706 case NOTIFICATION_RENDERER_PROCESS_CLOSING: |
| 675 RendererProcessClosing( | 707 RendererProcessClosing( |
| (...skipping 1036 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1712 void RenderFrameHostManager::DeleteRenderFrameProxyHost( | 1744 void RenderFrameHostManager::DeleteRenderFrameProxyHost( |
| 1713 SiteInstance* instance) { | 1745 SiteInstance* instance) { |
| 1714 RenderFrameProxyHostMap::iterator iter = proxy_hosts_.find(instance->GetId()); | 1746 RenderFrameProxyHostMap::iterator iter = proxy_hosts_.find(instance->GetId()); |
| 1715 if (iter != proxy_hosts_.end()) { | 1747 if (iter != proxy_hosts_.end()) { |
| 1716 delete iter->second; | 1748 delete iter->second; |
| 1717 proxy_hosts_.erase(iter); | 1749 proxy_hosts_.erase(iter); |
| 1718 } | 1750 } |
| 1719 } | 1751 } |
| 1720 | 1752 |
| 1721 } // namespace content | 1753 } // namespace content |
| OLD | NEW |