OLD | NEW |
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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/navigation_request.h" | 5 #include "content/browser/frame_host/navigation_request.h" |
6 | 6 |
7 #include <utility> | 7 #include <utility> |
8 | 8 |
9 #include "content/browser/child_process_security_policy_impl.h" | 9 #include "content/browser/child_process_security_policy_impl.h" |
10 #include "content/browser/devtools/render_frame_devtools_agent_host.h" | 10 #include "content/browser/devtools/render_frame_devtools_agent_host.h" |
(...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
211 const BeginNavigationParams& begin_params, | 211 const BeginNavigationParams& begin_params, |
212 const RequestNavigationParams& request_params, | 212 const RequestNavigationParams& request_params, |
213 bool browser_initiated, | 213 bool browser_initiated, |
214 const FrameNavigationEntry* frame_entry, | 214 const FrameNavigationEntry* frame_entry, |
215 const NavigationEntryImpl* entry) | 215 const NavigationEntryImpl* entry) |
216 : frame_tree_node_(frame_tree_node), | 216 : frame_tree_node_(frame_tree_node), |
217 common_params_(common_params), | 217 common_params_(common_params), |
218 begin_params_(begin_params), | 218 begin_params_(begin_params), |
219 request_params_(request_params), | 219 request_params_(request_params), |
220 browser_initiated_(browser_initiated), | 220 browser_initiated_(browser_initiated), |
| 221 is_srcdoc_(false), |
221 state_(NOT_STARTED), | 222 state_(NOT_STARTED), |
222 restore_type_(RestoreType::NONE), | 223 restore_type_(RestoreType::NONE), |
223 is_view_source_(false), | 224 is_view_source_(false), |
224 bindings_(NavigationEntryImpl::kInvalidBindings), | 225 bindings_(NavigationEntryImpl::kInvalidBindings), |
225 associated_site_instance_type_(AssociatedSiteInstanceType::NONE) { | 226 associated_site_instance_type_(AssociatedSiteInstanceType::NONE) { |
226 DCHECK(!browser_initiated || (entry != nullptr && frame_entry != nullptr)); | 227 DCHECK(!browser_initiated || (entry != nullptr && frame_entry != nullptr)); |
227 if (browser_initiated) { | 228 if (browser_initiated) { |
228 FrameNavigationEntry* frame_entry = entry->GetFrameEntry(frame_tree_node); | 229 FrameNavigationEntry* frame_entry = entry->GetFrameEntry(frame_tree_node); |
229 if (frame_entry) { | 230 if (frame_entry) { |
230 source_site_instance_ = frame_entry->source_site_instance(); | 231 source_site_instance_ = frame_entry->source_site_instance(); |
231 dest_site_instance_ = frame_entry->site_instance(); | 232 dest_site_instance_ = frame_entry->site_instance(); |
| 233 is_srcdoc_ = frame_entry->is_srcdoc(); |
232 } | 234 } |
233 | 235 |
234 restore_type_ = entry->restore_type(); | 236 restore_type_ = entry->restore_type(); |
235 is_view_source_ = entry->IsViewSourceMode(); | 237 is_view_source_ = entry->IsViewSourceMode(); |
236 bindings_ = entry->bindings(); | 238 bindings_ = entry->bindings(); |
237 } else { | 239 } else { |
238 // This is needed to have about:blank and data URLs commit in the same | 240 // This is needed to have about:blank and data URLs commit in the same |
239 // SiteInstance as the initiating renderer. | 241 // SiteInstance as the initiating renderer. |
240 source_site_instance_ = | 242 source_site_instance_ = |
241 frame_tree_node->current_frame_host()->GetSiteInstance(); | 243 frame_tree_node->current_frame_host()->GetSiteInstance(); |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
278 begin_params_.request_context_type, | 280 begin_params_.request_context_type, |
279 base::Bind(&NavigationRequest::OnStartChecksComplete, | 281 base::Bind(&NavigationRequest::OnStartChecksComplete, |
280 base::Unretained(this))); | 282 base::Unretained(this))); |
281 return; | 283 return; |
282 } | 284 } |
283 | 285 |
284 // There is no need to make a network request for this navigation, so commit | 286 // There is no need to make a network request for this navigation, so commit |
285 // it immediately. | 287 // it immediately. |
286 state_ = RESPONSE_STARTED; | 288 state_ = RESPONSE_STARTED; |
287 | 289 |
| 290 // Iframes with the srcdoc attribute have the "about:srcdoc" URL inside the |
| 291 // renderer and the "about:blank" URL inside the browser. The conversion is |
| 292 // made in RenderFrameHostImpl::OnDidCommitProvisionalLoad. The initial url |
| 293 // must be restored here when the navigation is committed into the renderer. |
| 294 if (is_srcdoc_) |
| 295 common_params_.url = GURL(content::kAboutSrcDocURL); |
| 296 |
288 // Select an appropriate RenderFrameHost. | 297 // Select an appropriate RenderFrameHost. |
289 RenderFrameHostImpl* render_frame_host = | 298 RenderFrameHostImpl* render_frame_host = |
290 frame_tree_node_->render_manager()->GetFrameHostForNavigation(*this); | 299 frame_tree_node_->render_manager()->GetFrameHostForNavigation(*this); |
291 NavigatorImpl::CheckWebUIRendererDoesNotDisplayNormalURL(render_frame_host, | 300 NavigatorImpl::CheckWebUIRendererDoesNotDisplayNormalURL(render_frame_host, |
292 common_params_.url); | 301 common_params_.url); |
293 | 302 |
294 // Inform the NavigationHandle that the navigation will commit. | 303 // Inform the NavigationHandle that the navigation will commit. |
295 navigation_handle_->ReadyToCommitNavigation(render_frame_host); | 304 navigation_handle_->ReadyToCommitNavigation(render_frame_host); |
296 | 305 |
297 CommitNavigation(); | 306 CommitNavigation(); |
298 } | 307 } |
299 | 308 |
300 void NavigationRequest::CreateNavigationHandle(int pending_nav_entry_id) { | 309 void NavigationRequest::CreateNavigationHandle(int pending_nav_entry_id) { |
301 // TODO(nasko): Update the NavigationHandle creation to ensure that the | 310 // TODO(nasko): Update the NavigationHandle creation to ensure that the |
302 // proper values are specified for is_same_page and is_srcdoc. | 311 // proper values is specified for is_same_page. |
303 navigation_handle_ = NavigationHandleImpl::Create( | 312 navigation_handle_ = NavigationHandleImpl::Create( |
304 common_params_.url, frame_tree_node_, !browser_initiated_, | 313 common_params_.url, frame_tree_node_, !browser_initiated_, |
305 false, // is_same_page | 314 false, // is_same_page |
306 false, // is_srcdoc | 315 is_srcdoc_, // is_srcdoc |
307 common_params_.navigation_start, pending_nav_entry_id, | 316 common_params_.navigation_start, pending_nav_entry_id, |
308 false); // started_in_context_menu | 317 false); // started_in_context_menu |
309 } | 318 } |
310 | 319 |
311 void NavigationRequest::TransferNavigationHandleOwnership( | 320 void NavigationRequest::TransferNavigationHandleOwnership( |
312 RenderFrameHostImpl* render_frame_host) { | 321 RenderFrameHostImpl* render_frame_host) { |
313 render_frame_host->SetNavigationHandle(std::move(navigation_handle_)); | 322 render_frame_host->SetNavigationHandle(std::move(navigation_handle_)); |
314 } | 323 } |
315 | 324 |
316 void NavigationRequest::OnRequestRedirected( | 325 void NavigationRequest::OnRequestRedirected( |
(...skipping 272 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
589 DCHECK_EQ(request_params_.has_user_gesture, begin_params_.has_user_gesture); | 598 DCHECK_EQ(request_params_.has_user_gesture, begin_params_.has_user_gesture); |
590 | 599 |
591 render_frame_host->CommitNavigation(response_.get(), std::move(body_), | 600 render_frame_host->CommitNavigation(response_.get(), std::move(body_), |
592 common_params_, request_params_, | 601 common_params_, request_params_, |
593 is_view_source_); | 602 is_view_source_); |
594 | 603 |
595 frame_tree_node_->ResetNavigationRequest(true); | 604 frame_tree_node_->ResetNavigationRequest(true); |
596 } | 605 } |
597 | 606 |
598 } // namespace content | 607 } // namespace content |
OLD | NEW |