| 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/renderer/render_frame_impl.h" | 5 #include "content/renderer/render_frame_impl.h" | 
| 6 | 6 | 
| 7 #include <map> | 7 #include <map> | 
| 8 #include <string> | 8 #include <string> | 
| 9 #include <utility> | 9 #include <utility> | 
| 10 #include <vector> | 10 #include <vector> | 
| (...skipping 984 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 995         RenderFrameImpl::Create(parent_proxy->render_view(), routing_id); | 995         RenderFrameImpl::Create(parent_proxy->render_view(), routing_id); | 
| 996     render_frame->InitializeBlameContext(FromRoutingID(parent_routing_id)); | 996     render_frame->InitializeBlameContext(FromRoutingID(parent_routing_id)); | 
| 997     render_frame->unique_name_helper_.set_propagated_name( | 997     render_frame->unique_name_helper_.set_propagated_name( | 
| 998         replicated_state.unique_name); | 998         replicated_state.unique_name); | 
| 999     web_frame = parent_web_frame->CreateLocalChild( | 999     web_frame = parent_web_frame->CreateLocalChild( | 
| 1000         replicated_state.scope, WebString::FromUTF8(replicated_state.name), | 1000         replicated_state.scope, WebString::FromUTF8(replicated_state.name), | 
| 1001         replicated_state.sandbox_flags, render_frame, | 1001         replicated_state.sandbox_flags, render_frame, | 
| 1002         render_frame->blink_interface_provider_.get(), | 1002         render_frame->blink_interface_provider_.get(), | 
| 1003         render_frame->blink_interface_registry_.get(), | 1003         render_frame->blink_interface_registry_.get(), | 
| 1004         previous_sibling_web_frame, | 1004         previous_sibling_web_frame, | 
|  | 1005         FeaturePolicyHeaderToWeb(replicated_state.container_policy), | 
| 1005         ConvertFrameOwnerPropertiesToWebFrameOwnerProperties( | 1006         ConvertFrameOwnerPropertiesToWebFrameOwnerProperties( | 
| 1006             frame_owner_properties), | 1007             frame_owner_properties), | 
| 1007         ResolveOpener(opener_routing_id)); | 1008         ResolveOpener(opener_routing_id)); | 
| 1008 | 1009 | 
| 1009     // The RenderFrame is created and inserted into the frame tree in the above | 1010     // The RenderFrame is created and inserted into the frame tree in the above | 
| 1010     // call to createLocalChild. | 1011     // call to createLocalChild. | 
| 1011     render_frame->in_frame_tree_ = true; | 1012     render_frame->in_frame_tree_ = true; | 
| 1012   } else { | 1013   } else { | 
| 1013     RenderFrameProxy* proxy = | 1014     RenderFrameProxy* proxy = | 
| 1014         RenderFrameProxy::FromRoutingID(proxy_routing_id); | 1015         RenderFrameProxy::FromRoutingID(proxy_routing_id); | 
| (...skipping 566 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 1581     IPC_MESSAGE_HANDLER(FrameMsg_ReloadLoFiImages, OnReloadLoFiImages) | 1582     IPC_MESSAGE_HANDLER(FrameMsg_ReloadLoFiImages, OnReloadLoFiImages) | 
| 1582     IPC_MESSAGE_HANDLER(FrameMsg_TextSurroundingSelectionRequest, | 1583     IPC_MESSAGE_HANDLER(FrameMsg_TextSurroundingSelectionRequest, | 
| 1583                         OnTextSurroundingSelectionRequest) | 1584                         OnTextSurroundingSelectionRequest) | 
| 1584     IPC_MESSAGE_HANDLER(FrameMsg_SetAccessibilityMode, | 1585     IPC_MESSAGE_HANDLER(FrameMsg_SetAccessibilityMode, | 
| 1585                         OnSetAccessibilityMode) | 1586                         OnSetAccessibilityMode) | 
| 1586     IPC_MESSAGE_HANDLER(AccessibilityMsg_SnapshotTree, | 1587     IPC_MESSAGE_HANDLER(AccessibilityMsg_SnapshotTree, | 
| 1587                         OnSnapshotAccessibilityTree) | 1588                         OnSnapshotAccessibilityTree) | 
| 1588     IPC_MESSAGE_HANDLER(FrameMsg_ExtractSmartClipData, OnExtractSmartClipData) | 1589     IPC_MESSAGE_HANDLER(FrameMsg_ExtractSmartClipData, OnExtractSmartClipData) | 
| 1589     IPC_MESSAGE_HANDLER(FrameMsg_UpdateOpener, OnUpdateOpener) | 1590     IPC_MESSAGE_HANDLER(FrameMsg_UpdateOpener, OnUpdateOpener) | 
| 1590     IPC_MESSAGE_HANDLER(FrameMsg_CommitNavigation, OnCommitNavigation) | 1591     IPC_MESSAGE_HANDLER(FrameMsg_CommitNavigation, OnCommitNavigation) | 
| 1591     IPC_MESSAGE_HANDLER(FrameMsg_DidUpdateSandboxFlags, OnDidUpdateSandboxFlags) | 1592     IPC_MESSAGE_HANDLER(FrameMsg_DidUpdateFramePolicy, OnDidUpdateFramePolicy) | 
| 1592     IPC_MESSAGE_HANDLER(FrameMsg_SetFrameOwnerProperties, | 1593     IPC_MESSAGE_HANDLER(FrameMsg_SetFrameOwnerProperties, | 
| 1593                         OnSetFrameOwnerProperties) | 1594                         OnSetFrameOwnerProperties) | 
| 1594     IPC_MESSAGE_HANDLER(FrameMsg_AdvanceFocus, OnAdvanceFocus) | 1595     IPC_MESSAGE_HANDLER(FrameMsg_AdvanceFocus, OnAdvanceFocus) | 
| 1595     IPC_MESSAGE_HANDLER(FrameMsg_SetFocusedFrame, OnSetFocusedFrame) | 1596     IPC_MESSAGE_HANDLER(FrameMsg_SetFocusedFrame, OnSetFocusedFrame) | 
| 1596     IPC_MESSAGE_HANDLER(FrameMsg_SetTextTrackSettings, | 1597     IPC_MESSAGE_HANDLER(FrameMsg_SetTextTrackSettings, | 
| 1597                         OnTextTrackSettingsChanged) | 1598                         OnTextTrackSettingsChanged) | 
| 1598     IPC_MESSAGE_HANDLER(FrameMsg_PostMessageEvent, OnPostMessageEvent) | 1599     IPC_MESSAGE_HANDLER(FrameMsg_PostMessageEvent, OnPostMessageEvent) | 
| 1599     IPC_MESSAGE_HANDLER(FrameMsg_FailedNavigation, OnFailedNavigation) | 1600     IPC_MESSAGE_HANDLER(FrameMsg_FailedNavigation, OnFailedNavigation) | 
| 1600     IPC_MESSAGE_HANDLER(FrameMsg_ReportContentSecurityPolicyViolation, | 1601     IPC_MESSAGE_HANDLER(FrameMsg_ReportContentSecurityPolicyViolation, | 
| 1601                         OnReportContentSecurityPolicyViolation) | 1602                         OnReportContentSecurityPolicyViolation) | 
| (...skipping 585 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 2187   GetWebFrame()->ExtractSmartClipData(rect, clip_text, clip_html); | 2188   GetWebFrame()->ExtractSmartClipData(rect, clip_text, clip_html); | 
| 2188   Send(new FrameHostMsg_SmartClipDataExtracted( | 2189   Send(new FrameHostMsg_SmartClipDataExtracted( | 
| 2189       routing_id_, id, clip_text.Utf16(), clip_html.Utf16())); | 2190       routing_id_, id, clip_text.Utf16(), clip_html.Utf16())); | 
| 2190 } | 2191 } | 
| 2191 | 2192 | 
| 2192 void RenderFrameImpl::OnUpdateOpener(int opener_routing_id) { | 2193 void RenderFrameImpl::OnUpdateOpener(int opener_routing_id) { | 
| 2193   WebFrame* opener = ResolveOpener(opener_routing_id); | 2194   WebFrame* opener = ResolveOpener(opener_routing_id); | 
| 2194   frame_->SetOpener(opener); | 2195   frame_->SetOpener(opener); | 
| 2195 } | 2196 } | 
| 2196 | 2197 | 
| 2197 void RenderFrameImpl::OnDidUpdateSandboxFlags(blink::WebSandboxFlags flags) { | 2198 void RenderFrameImpl::OnDidUpdateFramePolicy( | 
| 2198   frame_->SetFrameOwnerSandboxFlags(flags); | 2199     blink::WebSandboxFlags flags, | 
|  | 2200     const ParsedFeaturePolicyHeader& container_policy) { | 
|  | 2201   frame_->SetFrameOwnerPolicy(flags, | 
|  | 2202                               FeaturePolicyHeaderToWeb(container_policy)); | 
| 2199 } | 2203 } | 
| 2200 | 2204 | 
| 2201 void RenderFrameImpl::OnSetFrameOwnerProperties( | 2205 void RenderFrameImpl::OnSetFrameOwnerProperties( | 
| 2202     const FrameOwnerProperties& frame_owner_properties) { | 2206     const FrameOwnerProperties& frame_owner_properties) { | 
| 2203   DCHECK(frame_); | 2207   DCHECK(frame_); | 
| 2204   frame_->SetFrameOwnerProperties( | 2208   frame_->SetFrameOwnerProperties( | 
| 2205       ConvertFrameOwnerPropertiesToWebFrameOwnerProperties( | 2209       ConvertFrameOwnerPropertiesToWebFrameOwnerProperties( | 
| 2206           frame_owner_properties)); | 2210           frame_owner_properties)); | 
| 2207 } | 2211 } | 
| 2208 | 2212 | 
| (...skipping 863 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 3072 | 3076 | 
| 3073   has_accessed_initial_document_ = true; | 3077   has_accessed_initial_document_ = true; | 
| 3074 } | 3078 } | 
| 3075 | 3079 | 
| 3076 blink::WebLocalFrame* RenderFrameImpl::CreateChildFrame( | 3080 blink::WebLocalFrame* RenderFrameImpl::CreateChildFrame( | 
| 3077     blink::WebLocalFrame* parent, | 3081     blink::WebLocalFrame* parent, | 
| 3078     blink::WebTreeScopeType scope, | 3082     blink::WebTreeScopeType scope, | 
| 3079     const blink::WebString& name, | 3083     const blink::WebString& name, | 
| 3080     const blink::WebString& fallback_name, | 3084     const blink::WebString& fallback_name, | 
| 3081     blink::WebSandboxFlags sandbox_flags, | 3085     blink::WebSandboxFlags sandbox_flags, | 
|  | 3086     const blink::WebParsedFeaturePolicy& container_policy, | 
| 3082     const blink::WebFrameOwnerProperties& frame_owner_properties) { | 3087     const blink::WebFrameOwnerProperties& frame_owner_properties) { | 
| 3083   // Synchronously notify the browser of a child frame creation to get the | 3088   // Synchronously notify the browser of a child frame creation to get the | 
| 3084   // routing_id for the RenderFrame. | 3089   // routing_id for the RenderFrame. | 
| 3085   int child_routing_id = MSG_ROUTING_NONE; | 3090   int child_routing_id = MSG_ROUTING_NONE; | 
| 3086   FrameHostMsg_CreateChildFrame_Params params; | 3091   FrameHostMsg_CreateChildFrame_Params params; | 
| 3087   params.parent_routing_id = routing_id_; | 3092   params.parent_routing_id = routing_id_; | 
| 3088   params.scope = scope; | 3093   params.scope = scope; | 
| 3089   params.frame_name = name.Utf8(); | 3094   params.frame_name = name.Utf8(); | 
| 3090   // The unique name generation logic was moved out of Blink, so for historical | 3095   // The unique name generation logic was moved out of Blink, so for historical | 
| 3091   // reasons, unique name generation needs to take something called the | 3096   // reasons, unique name generation needs to take something called the | 
| 3092   // |fallback_name| into account. Normally, unique names are generated based on | 3097   // |fallback_name| into account. Normally, unique names are generated based on | 
| 3093   // the browing context name. For new frames, the initial browsing context name | 3098   // the browing context name. For new frames, the initial browsing context name | 
| 3094   // comes from the name attribute of the browsing context container element. | 3099   // comes from the name attribute of the browsing context container element. | 
| 3095   // | 3100   // | 
| 3096   // However, when the browsing context name is null, Blink instead uses the | 3101   // However, when the browsing context name is null, Blink instead uses the | 
| 3097   // "fallback name" to derive the unique name. The exact contents of the | 3102   // "fallback name" to derive the unique name. The exact contents of the | 
| 3098   // "fallback name" are unspecified, but may contain the value of the | 3103   // "fallback name" are unspecified, but may contain the value of the | 
| 3099   // 'subresource attribute' of the browsing context container element. | 3104   // 'subresource attribute' of the browsing context container element. | 
| 3100   // | 3105   // | 
| 3101   // Note that Blink can't be changed to just pass |fallback_name| as |name| in | 3106   // Note that Blink can't be changed to just pass |fallback_name| as |name| in | 
| 3102   // the case |name| is empty: |fallback_name| should never affect the actual | 3107   // the case |name| is empty: |fallback_name| should never affect the actual | 
| 3103   // browsing context name, only unique name generation. | 3108   // browsing context name, only unique name generation. | 
| 3104   params.frame_unique_name = UniqueNameHelper::GenerateNameForNewChildFrame( | 3109   params.frame_unique_name = UniqueNameHelper::GenerateNameForNewChildFrame( | 
| 3105       parent, | 3110       parent, | 
| 3106       params.frame_name.empty() ? fallback_name.Utf8() : params.frame_name); | 3111       params.frame_name.empty() ? fallback_name.Utf8() : params.frame_name); | 
| 3107   params.sandbox_flags = sandbox_flags; | 3112   params.sandbox_flags = sandbox_flags; | 
|  | 3113   params.container_policy = FeaturePolicyHeaderFromWeb(container_policy); | 
| 3108   params.frame_owner_properties = | 3114   params.frame_owner_properties = | 
| 3109       ConvertWebFrameOwnerPropertiesToFrameOwnerProperties( | 3115       ConvertWebFrameOwnerPropertiesToFrameOwnerProperties( | 
| 3110           frame_owner_properties); | 3116           frame_owner_properties); | 
| 3111   Send(new FrameHostMsg_CreateChildFrame(params, &child_routing_id)); | 3117   Send(new FrameHostMsg_CreateChildFrame(params, &child_routing_id)); | 
| 3112 | 3118 | 
| 3113   // Allocation of routing id failed, so we can't create a child frame. This can | 3119   // Allocation of routing id failed, so we can't create a child frame. This can | 
| 3114   // happen if the synchronous IPC message above has failed.  This can | 3120   // happen if the synchronous IPC message above has failed.  This can | 
| 3115   // legitimately happen when the browser process has already destroyed | 3121   // legitimately happen when the browser process has already destroyed | 
| 3116   // RenderProcessHost, but the renderer process hasn't quit yet. | 3122   // RenderProcessHost, but the renderer process hasn't quit yet. | 
| 3117   if (child_routing_id == MSG_ROUTING_NONE) | 3123   if (child_routing_id == MSG_ROUTING_NONE) | 
| (...skipping 137 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 3255     blink::WebInsecureRequestPolicy policy) { | 3261     blink::WebInsecureRequestPolicy policy) { | 
| 3256   Send(new FrameHostMsg_EnforceInsecureRequestPolicy(routing_id_, policy)); | 3262   Send(new FrameHostMsg_EnforceInsecureRequestPolicy(routing_id_, policy)); | 
| 3257 } | 3263 } | 
| 3258 | 3264 | 
| 3259 void RenderFrameImpl::DidUpdateToUniqueOrigin( | 3265 void RenderFrameImpl::DidUpdateToUniqueOrigin( | 
| 3260     bool is_potentially_trustworthy_unique_origin) { | 3266     bool is_potentially_trustworthy_unique_origin) { | 
| 3261   Send(new FrameHostMsg_UpdateToUniqueOrigin( | 3267   Send(new FrameHostMsg_UpdateToUniqueOrigin( | 
| 3262       routing_id_, is_potentially_trustworthy_unique_origin)); | 3268       routing_id_, is_potentially_trustworthy_unique_origin)); | 
| 3263 } | 3269 } | 
| 3264 | 3270 | 
| 3265 void RenderFrameImpl::DidChangeSandboxFlags(blink::WebFrame* child_frame, | 3271 void RenderFrameImpl::DidChangeFramePolicy( | 
| 3266                                             blink::WebSandboxFlags flags) { | 3272     blink::WebFrame* child_frame, | 
| 3267   Send(new FrameHostMsg_DidChangeSandboxFlags( | 3273     blink::WebSandboxFlags flags, | 
| 3268       routing_id_, GetRoutingIdForFrameOrProxy(child_frame), flags)); | 3274     const blink::WebParsedFeaturePolicy& container_policy) { | 
|  | 3275   Send(new FrameHostMsg_DidChangeFramePolicy( | 
|  | 3276       routing_id_, GetRoutingIdForFrameOrProxy(child_frame), flags, | 
|  | 3277       FeaturePolicyHeaderFromWeb(container_policy))); | 
| 3269 } | 3278 } | 
| 3270 | 3279 | 
| 3271 void RenderFrameImpl::DidSetFeaturePolicyHeader( | 3280 void RenderFrameImpl::DidSetFeaturePolicyHeader( | 
| 3272     const blink::WebParsedFeaturePolicy& parsed_header) { | 3281     const blink::WebParsedFeaturePolicy& parsed_header) { | 
| 3273   Send(new FrameHostMsg_DidSetFeaturePolicyHeader( | 3282   Send(new FrameHostMsg_DidSetFeaturePolicyHeader( | 
| 3274       routing_id_, FeaturePolicyHeaderFromWeb(parsed_header))); | 3283       routing_id_, FeaturePolicyHeaderFromWeb(parsed_header))); | 
| 3275 } | 3284 } | 
| 3276 | 3285 | 
| 3277 void RenderFrameImpl::DidAddContentSecurityPolicies( | 3286 void RenderFrameImpl::DidAddContentSecurityPolicies( | 
| 3278     const blink::WebVector<blink::WebContentSecurityPolicy>& policies) { | 3287     const blink::WebVector<blink::WebContentSecurityPolicy>& policies) { | 
| (...skipping 3712 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 6991       policy(info.default_policy), | 7000       policy(info.default_policy), | 
| 6992       replaces_current_history_item(info.replaces_current_history_item), | 7001       replaces_current_history_item(info.replaces_current_history_item), | 
| 6993       history_navigation_in_new_child_frame( | 7002       history_navigation_in_new_child_frame( | 
| 6994           info.is_history_navigation_in_new_child_frame), | 7003           info.is_history_navigation_in_new_child_frame), | 
| 6995       client_redirect(info.is_client_redirect), | 7004       client_redirect(info.is_client_redirect), | 
| 6996       cache_disabled(info.is_cache_disabled), | 7005       cache_disabled(info.is_cache_disabled), | 
| 6997       form(info.form), | 7006       form(info.form), | 
| 6998       source_location(info.source_location) {} | 7007       source_location(info.source_location) {} | 
| 6999 | 7008 | 
| 7000 }  // namespace content | 7009 }  // namespace content | 
| OLD | NEW | 
|---|