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> |
11 | 11 |
12 #include "base/auto_reset.h" | 12 #include "base/auto_reset.h" |
13 #include "base/command_line.h" | 13 #include "base/command_line.h" |
14 #include "base/debug/alias.h" | 14 #include "base/debug/alias.h" |
15 #include "base/debug/asan_invalid_access.h" | 15 #include "base/debug/asan_invalid_access.h" |
16 #include "base/debug/crash_logging.h" | 16 #include "base/debug/crash_logging.h" |
17 #include "base/debug/dump_without_crashing.h" | 17 #include "base/debug/dump_without_crashing.h" |
18 #include "base/files/file.h" | 18 #include "base/files/file.h" |
19 #include "base/i18n/char_iterator.h" | 19 #include "base/i18n/char_iterator.h" |
20 #include "base/logging.h" | 20 #include "base/logging.h" |
21 #include "base/macros.h" | 21 #include "base/macros.h" |
| 22 #include "base/memory/ptr_util.h" |
22 #include "base/memory/shared_memory.h" | 23 #include "base/memory/shared_memory.h" |
23 #include "base/memory/weak_ptr.h" | 24 #include "base/memory/weak_ptr.h" |
24 #include "base/metrics/field_trial.h" | 25 #include "base/metrics/field_trial.h" |
25 #include "base/metrics/histogram.h" | 26 #include "base/metrics/histogram.h" |
26 #include "base/process/process.h" | 27 #include "base/process/process.h" |
27 #include "base/stl_util.h" | 28 #include "base/stl_util.h" |
28 #include "base/strings/string16.h" | 29 #include "base/strings/string16.h" |
29 #include "base/strings/utf_string_conversions.h" | 30 #include "base/strings/utf_string_conversions.h" |
30 #include "base/thread_task_runner_handle.h" | 31 #include "base/thread_task_runner_handle.h" |
31 #include "base/time/time.h" | 32 #include "base/time/time.h" |
(...skipping 467 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
499 #endif // ADDRESS_SANITIZER || SYZYASAN | 500 #endif // ADDRESS_SANITIZER || SYZYASAN |
500 } | 501 } |
501 | 502 |
502 // Returns false unless this is a top-level navigation. | 503 // Returns false unless this is a top-level navigation. |
503 bool IsTopLevelNavigation(WebFrame* frame) { | 504 bool IsTopLevelNavigation(WebFrame* frame) { |
504 return frame->parent() == NULL; | 505 return frame->parent() == NULL; |
505 } | 506 } |
506 | 507 |
507 WebURLRequest CreateURLRequestForNavigation( | 508 WebURLRequest CreateURLRequestForNavigation( |
508 const CommonNavigationParams& common_params, | 509 const CommonNavigationParams& common_params, |
509 scoped_ptr<StreamOverrideParameters> stream_override, | 510 std::unique_ptr<StreamOverrideParameters> stream_override, |
510 bool is_view_source_mode_enabled) { | 511 bool is_view_source_mode_enabled) { |
511 WebURLRequest request(common_params.url); | 512 WebURLRequest request(common_params.url); |
512 if (is_view_source_mode_enabled) | 513 if (is_view_source_mode_enabled) |
513 request.setCachePolicy(WebCachePolicy::ReturnCacheDataElseLoad); | 514 request.setCachePolicy(WebCachePolicy::ReturnCacheDataElseLoad); |
514 | 515 |
515 if (common_params.referrer.url.is_valid()) { | 516 if (common_params.referrer.url.is_valid()) { |
516 WebString web_referrer = WebSecurityPolicy::generateReferrerHeader( | 517 WebString web_referrer = WebSecurityPolicy::generateReferrerHeader( |
517 common_params.referrer.policy, | 518 common_params.referrer.policy, |
518 common_params.url, | 519 common_params.url, |
519 WebString::fromUTF8(common_params.referrer.url.spec())); | 520 WebString::fromUTF8(common_params.referrer.url.spec())); |
(...skipping 956 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1476 } | 1477 } |
1477 | 1478 |
1478 RenderThreadImpl* render_thread_impl = RenderThreadImpl::current(); | 1479 RenderThreadImpl* render_thread_impl = RenderThreadImpl::current(); |
1479 // Can be NULL in tests. | 1480 // Can be NULL in tests. |
1480 if (render_thread_impl) | 1481 if (render_thread_impl) |
1481 render_thread_impl->GetRendererScheduler()->OnNavigationStarted(); | 1482 render_thread_impl->GetRendererScheduler()->OnNavigationStarted(); |
1482 DCHECK(!IsBrowserSideNavigationEnabled()); | 1483 DCHECK(!IsBrowserSideNavigationEnabled()); |
1483 TRACE_EVENT2("navigation", "RenderFrameImpl::OnNavigate", "id", routing_id_, | 1484 TRACE_EVENT2("navigation", "RenderFrameImpl::OnNavigate", "id", routing_id_, |
1484 "url", common_params.url.possibly_invalid_spec()); | 1485 "url", common_params.url.possibly_invalid_spec()); |
1485 NavigateInternal(common_params, start_params, request_params, | 1486 NavigateInternal(common_params, start_params, request_params, |
1486 scoped_ptr<StreamOverrideParameters>()); | 1487 std::unique_ptr<StreamOverrideParameters>()); |
1487 } | 1488 } |
1488 | 1489 |
1489 void RenderFrameImpl::BindServiceRegistry( | 1490 void RenderFrameImpl::BindServiceRegistry( |
1490 mojo::shell::mojom::InterfaceProviderRequest services, | 1491 mojo::shell::mojom::InterfaceProviderRequest services, |
1491 mojo::shell::mojom::InterfaceProviderPtr exposed_services) { | 1492 mojo::shell::mojom::InterfaceProviderPtr exposed_services) { |
1492 service_registry_.Bind(std::move(services)); | 1493 service_registry_.Bind(std::move(services)); |
1493 service_registry_.BindRemoteServiceProvider(std::move(exposed_services)); | 1494 service_registry_.BindRemoteServiceProvider(std::move(exposed_services)); |
1494 } | 1495 } |
1495 | 1496 |
1496 ManifestManager* RenderFrameImpl::manifest_manager() { | 1497 ManifestManager* RenderFrameImpl::manifest_manager() { |
1497 return manifest_manager_; | 1498 return manifest_manager_; |
1498 } | 1499 } |
1499 | 1500 |
1500 void RenderFrameImpl::SetPendingNavigationParams( | 1501 void RenderFrameImpl::SetPendingNavigationParams( |
1501 scoped_ptr<NavigationParams> navigation_params) { | 1502 std::unique_ptr<NavigationParams> navigation_params) { |
1502 pending_navigation_params_ = std::move(navigation_params); | 1503 pending_navigation_params_ = std::move(navigation_params); |
1503 } | 1504 } |
1504 | 1505 |
1505 void RenderFrameImpl::OnBeforeUnload() { | 1506 void RenderFrameImpl::OnBeforeUnload() { |
1506 TRACE_EVENT1("navigation", "RenderFrameImpl::OnBeforeUnload", | 1507 TRACE_EVENT1("navigation", "RenderFrameImpl::OnBeforeUnload", |
1507 "id", routing_id_); | 1508 "id", routing_id_); |
1508 // TODO(creis): Right now, this is only called on the main frame. Make the | 1509 // TODO(creis): Right now, this is only called on the main frame. Make the |
1509 // browser process send dispatchBeforeUnloadEvent to every frame that needs | 1510 // browser process send dispatchBeforeUnloadEvent to every frame that needs |
1510 // it. | 1511 // it. |
1511 CHECK(!frame_->parent()); | 1512 CHECK(!frame_->parent()); |
(...skipping 299 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1811 void RenderFrameImpl::OnJavaScriptExecuteRequestForTests( | 1812 void RenderFrameImpl::OnJavaScriptExecuteRequestForTests( |
1812 const base::string16& jscript, | 1813 const base::string16& jscript, |
1813 int id, | 1814 int id, |
1814 bool notify_result, | 1815 bool notify_result, |
1815 bool has_user_gesture) { | 1816 bool has_user_gesture) { |
1816 TRACE_EVENT_INSTANT0("test_tracing", "OnJavaScriptExecuteRequestForTests", | 1817 TRACE_EVENT_INSTANT0("test_tracing", "OnJavaScriptExecuteRequestForTests", |
1817 TRACE_EVENT_SCOPE_THREAD); | 1818 TRACE_EVENT_SCOPE_THREAD); |
1818 | 1819 |
1819 // A bunch of tests expect to run code in the context of a user gesture, which | 1820 // A bunch of tests expect to run code in the context of a user gesture, which |
1820 // can grant additional privileges (e.g. the ability to create popups). | 1821 // can grant additional privileges (e.g. the ability to create popups). |
1821 scoped_ptr<blink::WebScopedUserGesture> gesture( | 1822 std::unique_ptr<blink::WebScopedUserGesture> gesture( |
1822 has_user_gesture ? new blink::WebScopedUserGesture : nullptr); | 1823 has_user_gesture ? new blink::WebScopedUserGesture : nullptr); |
1823 v8::HandleScope handle_scope(blink::mainThreadIsolate()); | 1824 v8::HandleScope handle_scope(blink::mainThreadIsolate()); |
1824 v8::Local<v8::Value> result = | 1825 v8::Local<v8::Value> result = |
1825 frame_->executeScriptAndReturnValue(WebScriptSource(jscript)); | 1826 frame_->executeScriptAndReturnValue(WebScriptSource(jscript)); |
1826 | 1827 |
1827 HandleJavascriptExecutionResult(jscript, id, notify_result, result); | 1828 HandleJavascriptExecutionResult(jscript, id, notify_result, result); |
1828 } | 1829 } |
1829 | 1830 |
1830 void RenderFrameImpl::OnJavaScriptExecuteRequestInIsolatedWorld( | 1831 void RenderFrameImpl::OnJavaScriptExecuteRequestInIsolatedWorld( |
1831 const base::string16& jscript, | 1832 const base::string16& jscript, |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1880 // here. V8ValueConverterImpl shouldn't actually care about the | 1881 // here. V8ValueConverterImpl shouldn't actually care about the |
1881 // context scope, and it switches to v8::Object's creation context | 1882 // context scope, and it switches to v8::Object's creation context |
1882 // when encountered. (from extensions/renderer/script_injection.cc) | 1883 // when encountered. (from extensions/renderer/script_injection.cc) |
1883 v8::Local<v8::Context> context = | 1884 v8::Local<v8::Context> context = |
1884 render_frame_impl_.get()->frame_->mainWorldScriptContext(); | 1885 render_frame_impl_.get()->frame_->mainWorldScriptContext(); |
1885 v8::Context::Scope context_scope(context); | 1886 v8::Context::Scope context_scope(context); |
1886 V8ValueConverterImpl converter; | 1887 V8ValueConverterImpl converter; |
1887 converter.SetDateAllowed(true); | 1888 converter.SetDateAllowed(true); |
1888 converter.SetRegExpAllowed(true); | 1889 converter.SetRegExpAllowed(true); |
1889 for (const auto& value : result) { | 1890 for (const auto& value : result) { |
1890 scoped_ptr<base::Value> result_value( | 1891 std::unique_ptr<base::Value> result_value( |
1891 converter.FromV8Value(value, context)); | 1892 converter.FromV8Value(value, context)); |
1892 list.Append(result_value ? std::move(result_value) | 1893 list.Append(result_value ? std::move(result_value) |
1893 : base::Value::CreateNullValue()); | 1894 : base::Value::CreateNullValue()); |
1894 } | 1895 } |
1895 } else { | 1896 } else { |
1896 list.Set(0, base::Value::CreateNullValue()); | 1897 list.Set(0, base::Value::CreateNullValue()); |
1897 } | 1898 } |
1898 render_frame_impl_.get()->Send( | 1899 render_frame_impl_.get()->Send( |
1899 new FrameHostMsg_JavaScriptExecuteResponse(routing_id_, id_, list)); | 1900 new FrameHostMsg_JavaScriptExecuteResponse(routing_id_, id_, list)); |
1900 } | 1901 } |
1901 | 1902 |
1902 delete this; | 1903 delete this; |
1903 } | 1904 } |
1904 | 1905 |
1905 void RenderFrameImpl::HandleJavascriptExecutionResult( | 1906 void RenderFrameImpl::HandleJavascriptExecutionResult( |
1906 const base::string16& jscript, | 1907 const base::string16& jscript, |
1907 int id, | 1908 int id, |
1908 bool notify_result, | 1909 bool notify_result, |
1909 v8::Local<v8::Value> result) { | 1910 v8::Local<v8::Value> result) { |
1910 if (notify_result) { | 1911 if (notify_result) { |
1911 base::ListValue list; | 1912 base::ListValue list; |
1912 if (!result.IsEmpty()) { | 1913 if (!result.IsEmpty()) { |
1913 v8::Local<v8::Context> context = frame_->mainWorldScriptContext(); | 1914 v8::Local<v8::Context> context = frame_->mainWorldScriptContext(); |
1914 v8::Context::Scope context_scope(context); | 1915 v8::Context::Scope context_scope(context); |
1915 V8ValueConverterImpl converter; | 1916 V8ValueConverterImpl converter; |
1916 converter.SetDateAllowed(true); | 1917 converter.SetDateAllowed(true); |
1917 converter.SetRegExpAllowed(true); | 1918 converter.SetRegExpAllowed(true); |
1918 scoped_ptr<base::Value> result_value( | 1919 std::unique_ptr<base::Value> result_value( |
1919 converter.FromV8Value(result, context)); | 1920 converter.FromV8Value(result, context)); |
1920 list.Set(0, result_value ? std::move(result_value) | 1921 list.Set(0, result_value ? std::move(result_value) |
1921 : base::Value::CreateNullValue()); | 1922 : base::Value::CreateNullValue()); |
1922 } else { | 1923 } else { |
1923 list.Set(0, base::Value::CreateNullValue()); | 1924 list.Set(0, base::Value::CreateNullValue()); |
1924 } | 1925 } |
1925 Send(new FrameHostMsg_JavaScriptExecuteResponse(routing_id_, id, list)); | 1926 Send(new FrameHostMsg_JavaScriptExecuteResponse(routing_id_, id, list)); |
1926 } | 1927 } |
1927 } | 1928 } |
1928 | 1929 |
(...skipping 138 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2067 base::ThreadTaskRunnerHandle::Get().get()); | 2068 base::ThreadTaskRunnerHandle::Get().get()); |
2068 | 2069 |
2069 WebSerializedScriptValue serialized_script_value; | 2070 WebSerializedScriptValue serialized_script_value; |
2070 if (params.is_data_raw_string) { | 2071 if (params.is_data_raw_string) { |
2071 v8::HandleScope handle_scope(blink::mainThreadIsolate()); | 2072 v8::HandleScope handle_scope(blink::mainThreadIsolate()); |
2072 v8::Local<v8::Context> context = frame_->mainWorldScriptContext(); | 2073 v8::Local<v8::Context> context = frame_->mainWorldScriptContext(); |
2073 v8::Context::Scope context_scope(context); | 2074 v8::Context::Scope context_scope(context); |
2074 V8ValueConverterImpl converter; | 2075 V8ValueConverterImpl converter; |
2075 converter.SetDateAllowed(true); | 2076 converter.SetDateAllowed(true); |
2076 converter.SetRegExpAllowed(true); | 2077 converter.SetRegExpAllowed(true); |
2077 scoped_ptr<base::Value> value(new base::StringValue(params.data)); | 2078 std::unique_ptr<base::Value> value(new base::StringValue(params.data)); |
2078 v8::Local<v8::Value> result_value = converter.ToV8Value(value.get(), | 2079 v8::Local<v8::Value> result_value = converter.ToV8Value(value.get(), |
2079 context); | 2080 context); |
2080 serialized_script_value = WebSerializedScriptValue::serialize(result_value); | 2081 serialized_script_value = WebSerializedScriptValue::serialize(result_value); |
2081 } else { | 2082 } else { |
2082 serialized_script_value = WebSerializedScriptValue::fromString(params.data); | 2083 serialized_script_value = WebSerializedScriptValue::fromString(params.data); |
2083 } | 2084 } |
2084 | 2085 |
2085 // We must pass in the target_origin to do the security check on this side, | 2086 // We must pass in the target_origin to do the security check on this side, |
2086 // since it may have changed since the original postMessage call was made. | 2087 // since it may have changed since the original postMessage call was made. |
2087 WebSecurityOrigin target_origin; | 2088 WebSecurityOrigin target_origin; |
(...skipping 145 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2233 } | 2234 } |
2234 | 2235 |
2235 blink::WebNode RenderFrameImpl::GetContextMenuNode() const { | 2236 blink::WebNode RenderFrameImpl::GetContextMenuNode() const { |
2236 return context_menu_node_; | 2237 return context_menu_node_; |
2237 } | 2238 } |
2238 | 2239 |
2239 blink::WebPlugin* RenderFrameImpl::CreatePlugin( | 2240 blink::WebPlugin* RenderFrameImpl::CreatePlugin( |
2240 blink::WebFrame* frame, | 2241 blink::WebFrame* frame, |
2241 const WebPluginInfo& info, | 2242 const WebPluginInfo& info, |
2242 const blink::WebPluginParams& params, | 2243 const blink::WebPluginParams& params, |
2243 scoped_ptr<content::PluginInstanceThrottler> throttler) { | 2244 std::unique_ptr<content::PluginInstanceThrottler> throttler) { |
2244 DCHECK_EQ(frame_, frame); | 2245 DCHECK_EQ(frame_, frame); |
2245 #if defined(ENABLE_PLUGINS) | 2246 #if defined(ENABLE_PLUGINS) |
2246 if (info.type == WebPluginInfo::PLUGIN_TYPE_BROWSER_PLUGIN) { | 2247 if (info.type == WebPluginInfo::PLUGIN_TYPE_BROWSER_PLUGIN) { |
2247 return BrowserPluginManager::Get()->CreateBrowserPlugin( | 2248 return BrowserPluginManager::Get()->CreateBrowserPlugin( |
2248 this, GetContentClient() | 2249 this, GetContentClient() |
2249 ->renderer() | 2250 ->renderer() |
2250 ->CreateBrowserPluginDelegate(this, params.mimeType.utf8(), | 2251 ->CreateBrowserPluginDelegate(this, params.mimeType.utf8(), |
2251 GURL(params.url)) | 2252 GURL(params.url)) |
2252 ->GetWeakPtr()); | 2253 ->GetWeakPtr()); |
2253 } | 2254 } |
2254 | 2255 |
2255 bool pepper_plugin_was_registered = false; | 2256 bool pepper_plugin_was_registered = false; |
2256 scoped_refptr<PluginModule> pepper_module(PluginModule::Create( | 2257 scoped_refptr<PluginModule> pepper_module(PluginModule::Create( |
2257 this, info, &pepper_plugin_was_registered)); | 2258 this, info, &pepper_plugin_was_registered)); |
2258 if (pepper_plugin_was_registered) { | 2259 if (pepper_plugin_was_registered) { |
2259 if (pepper_module.get()) { | 2260 if (pepper_module.get()) { |
2260 return new PepperWebPluginImpl( | 2261 return new PepperWebPluginImpl( |
2261 pepper_module.get(), params, this, | 2262 pepper_module.get(), params, this, |
2262 make_scoped_ptr( | 2263 base::WrapUnique( |
2263 static_cast<PluginInstanceThrottlerImpl*>(throttler.release()))); | 2264 static_cast<PluginInstanceThrottlerImpl*>(throttler.release()))); |
2264 } | 2265 } |
2265 } | 2266 } |
2266 #if defined(OS_CHROMEOS) | 2267 #if defined(OS_CHROMEOS) |
2267 LOG(WARNING) << "Pepper module/plugin creation failed."; | 2268 LOG(WARNING) << "Pepper module/plugin creation failed."; |
2268 #endif | 2269 #endif |
2269 #endif | 2270 #endif |
2270 return NULL; | 2271 return NULL; |
2271 } | 2272 } |
2272 | 2273 |
(...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2456 initial_cdm, media_surface_manager_, media_session); | 2457 initial_cdm, media_surface_manager_, media_session); |
2457 | 2458 |
2458 #if defined(OS_ANDROID) | 2459 #if defined(OS_ANDROID) |
2459 if (GetContentClient()->renderer()->ShouldUseMediaPlayerForURL(url) || | 2460 if (GetContentClient()->renderer()->ShouldUseMediaPlayerForURL(url) || |
2460 !UseWebMediaPlayerImpl(url)) { | 2461 !UseWebMediaPlayerImpl(url)) { |
2461 return CreateAndroidWebMediaPlayer(client, encrypted_client, params); | 2462 return CreateAndroidWebMediaPlayer(client, encrypted_client, params); |
2462 } | 2463 } |
2463 #endif // defined(OS_ANDROID) | 2464 #endif // defined(OS_ANDROID) |
2464 | 2465 |
2465 #if defined(ENABLE_MOJO_RENDERER) | 2466 #if defined(ENABLE_MOJO_RENDERER) |
2466 scoped_ptr<media::RendererFactory> media_renderer_factory( | 2467 std::unique_ptr<media::RendererFactory> media_renderer_factory( |
2467 new media::MojoRendererFactory(GetMediaInterfaceProvider())); | 2468 new media::MojoRendererFactory(GetMediaInterfaceProvider())); |
2468 #else | 2469 #else |
2469 scoped_ptr<media::RendererFactory> media_renderer_factory = | 2470 std::unique_ptr<media::RendererFactory> media_renderer_factory = |
2470 GetContentClient()->renderer()->CreateMediaRendererFactory( | 2471 GetContentClient()->renderer()->CreateMediaRendererFactory( |
2471 this, render_thread->GetGpuFactories(), media_log); | 2472 this, render_thread->GetGpuFactories(), media_log); |
2472 | 2473 |
2473 if (!media_renderer_factory.get()) { | 2474 if (!media_renderer_factory.get()) { |
2474 media_renderer_factory.reset(new media::DefaultRendererFactory( | 2475 media_renderer_factory.reset(new media::DefaultRendererFactory( |
2475 media_log, GetDecoderFactory(), | 2476 media_log, GetDecoderFactory(), |
2476 base::Bind(&RenderThreadImpl::GetGpuFactories, | 2477 base::Bind(&RenderThreadImpl::GetGpuFactories, |
2477 base::Unretained(render_thread)), | 2478 base::Unretained(render_thread)), |
2478 *render_thread->GetAudioHardwareConfig())); | 2479 *render_thread->GetAudioHardwareConfig())); |
2479 } | 2480 } |
(...skipping 1244 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3724 request.setCachePolicy(internal_data->cache_policy_override()); | 3725 request.setCachePolicy(internal_data->cache_policy_override()); |
3725 | 3726 |
3726 // The request's extra data may indicate that we should set a custom user | 3727 // The request's extra data may indicate that we should set a custom user |
3727 // agent. This needs to be done here, after WebKit is through with setting the | 3728 // agent. This needs to be done here, after WebKit is through with setting the |
3728 // user agent on its own. Similarly, it may indicate that we should set an | 3729 // user agent on its own. Similarly, it may indicate that we should set an |
3729 // X-Requested-With header. This must be done here to avoid breaking CORS | 3730 // X-Requested-With header. This must be done here to avoid breaking CORS |
3730 // checks. | 3731 // checks. |
3731 // PlzNavigate: there may also be a stream url associated with the request. | 3732 // PlzNavigate: there may also be a stream url associated with the request. |
3732 WebString custom_user_agent; | 3733 WebString custom_user_agent; |
3733 WebString requested_with; | 3734 WebString requested_with; |
3734 scoped_ptr<StreamOverrideParameters> stream_override; | 3735 std::unique_ptr<StreamOverrideParameters> stream_override; |
3735 if (request.getExtraData()) { | 3736 if (request.getExtraData()) { |
3736 RequestExtraData* old_extra_data = | 3737 RequestExtraData* old_extra_data = |
3737 static_cast<RequestExtraData*>(request.getExtraData()); | 3738 static_cast<RequestExtraData*>(request.getExtraData()); |
3738 | 3739 |
3739 custom_user_agent = old_extra_data->custom_user_agent(); | 3740 custom_user_agent = old_extra_data->custom_user_agent(); |
3740 if (!custom_user_agent.isNull()) { | 3741 if (!custom_user_agent.isNull()) { |
3741 if (custom_user_agent.isEmpty()) | 3742 if (custom_user_agent.isEmpty()) |
3742 request.clearHTTPHeaderField("User-Agent"); | 3743 request.clearHTTPHeaderField("User-Agent"); |
3743 else | 3744 else |
3744 request.setHTTPHeaderField("User-Agent", custom_user_agent); | 3745 request.setHTTPHeaderField("User-Agent", custom_user_agent); |
(...skipping 862 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
4607 | 4608 |
4608 // PlzNavigate | 4609 // PlzNavigate |
4609 void RenderFrameImpl::OnCommitNavigation( | 4610 void RenderFrameImpl::OnCommitNavigation( |
4610 const ResourceResponseHead& response, | 4611 const ResourceResponseHead& response, |
4611 const GURL& stream_url, | 4612 const GURL& stream_url, |
4612 const CommonNavigationParams& common_params, | 4613 const CommonNavigationParams& common_params, |
4613 const RequestNavigationParams& request_params) { | 4614 const RequestNavigationParams& request_params) { |
4614 CHECK(IsBrowserSideNavigationEnabled()); | 4615 CHECK(IsBrowserSideNavigationEnabled()); |
4615 // This will override the url requested by the WebURLLoader, as well as | 4616 // This will override the url requested by the WebURLLoader, as well as |
4616 // provide it with the response to the request. | 4617 // provide it with the response to the request. |
4617 scoped_ptr<StreamOverrideParameters> stream_override( | 4618 std::unique_ptr<StreamOverrideParameters> stream_override( |
4618 new StreamOverrideParameters()); | 4619 new StreamOverrideParameters()); |
4619 stream_override->stream_url = stream_url; | 4620 stream_override->stream_url = stream_url; |
4620 stream_override->response = response; | 4621 stream_override->response = response; |
4621 | 4622 |
4622 NavigateInternal(common_params, StartNavigationParams(), request_params, | 4623 NavigateInternal(common_params, StartNavigationParams(), request_params, |
4623 std::move(stream_override)); | 4624 std::move(stream_override)); |
4624 } | 4625 } |
4625 | 4626 |
4626 // PlzNavigate | 4627 // PlzNavigate |
4627 void RenderFrameImpl::OnFailedNavigation( | 4628 void RenderFrameImpl::OnFailedNavigation( |
(...skipping 20 matching lines...) Expand all Loading... |
4648 | 4649 |
4649 // Inform the browser of the start of the provisional load. This is needed so | 4650 // Inform the browser of the start of the provisional load. This is needed so |
4650 // that the load is properly tracked by the WebNavigation API. | 4651 // that the load is properly tracked by the WebNavigation API. |
4651 Send(new FrameHostMsg_DidStartProvisionalLoad( | 4652 Send(new FrameHostMsg_DidStartProvisionalLoad( |
4652 routing_id_, common_params.url, common_params.navigation_start)); | 4653 routing_id_, common_params.url, common_params.navigation_start)); |
4653 | 4654 |
4654 // Send the provisional load failure. | 4655 // Send the provisional load failure. |
4655 blink::WebURLError error = | 4656 blink::WebURLError error = |
4656 CreateWebURLError(common_params.url, has_stale_copy_in_cache, error_code); | 4657 CreateWebURLError(common_params.url, has_stale_copy_in_cache, error_code); |
4657 WebURLRequest failed_request = CreateURLRequestForNavigation( | 4658 WebURLRequest failed_request = CreateURLRequestForNavigation( |
4658 common_params, scoped_ptr<StreamOverrideParameters>(), | 4659 common_params, std::unique_ptr<StreamOverrideParameters>(), |
4659 frame_->isViewSourceModeEnabled()); | 4660 frame_->isViewSourceModeEnabled()); |
4660 SendFailedProvisionalLoad(failed_request, error, frame_); | 4661 SendFailedProvisionalLoad(failed_request, error, frame_); |
4661 | 4662 |
4662 // This check should have been done on the browser side already. | 4663 // This check should have been done on the browser side already. |
4663 if (!ShouldDisplayErrorPageForFailedLoad(error_code, common_params.url)) { | 4664 if (!ShouldDisplayErrorPageForFailedLoad(error_code, common_params.url)) { |
4664 NOTREACHED(); | 4665 NOTREACHED(); |
4665 return; | 4666 return; |
4666 } | 4667 } |
4667 | 4668 |
4668 // Make sure errors are not shown in view source mode. | 4669 // Make sure errors are not shown in view source mode. |
(...skipping 540 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
5209 params.frame_unique_name = frame_->uniqueName().utf8(); | 5210 params.frame_unique_name = frame_->uniqueName().utf8(); |
5210 } | 5211 } |
5211 | 5212 |
5212 Send(new FrameHostMsg_OpenURL(routing_id_, params)); | 5213 Send(new FrameHostMsg_OpenURL(routing_id_, params)); |
5213 } | 5214 } |
5214 | 5215 |
5215 void RenderFrameImpl::NavigateInternal( | 5216 void RenderFrameImpl::NavigateInternal( |
5216 const CommonNavigationParams& common_params, | 5217 const CommonNavigationParams& common_params, |
5217 const StartNavigationParams& start_params, | 5218 const StartNavigationParams& start_params, |
5218 const RequestNavigationParams& request_params, | 5219 const RequestNavigationParams& request_params, |
5219 scoped_ptr<StreamOverrideParameters> stream_params) { | 5220 std::unique_ptr<StreamOverrideParameters> stream_params) { |
5220 bool browser_side_navigation = IsBrowserSideNavigationEnabled(); | 5221 bool browser_side_navigation = IsBrowserSideNavigationEnabled(); |
5221 | 5222 |
5222 // Lower bound for browser initiated navigation start time. | 5223 // Lower bound for browser initiated navigation start time. |
5223 base::TimeTicks renderer_navigation_start = base::TimeTicks::Now(); | 5224 base::TimeTicks renderer_navigation_start = base::TimeTicks::Now(); |
5224 bool is_reload = IsReload(common_params.navigation_type); | 5225 bool is_reload = IsReload(common_params.navigation_type); |
5225 bool is_history_navigation = request_params.page_state.IsValid(); | 5226 bool is_history_navigation = request_params.page_state.IsValid(); |
5226 WebCachePolicy cache_policy = WebCachePolicy::UseProtocolCachePolicy; | 5227 WebCachePolicy cache_policy = WebCachePolicy::UseProtocolCachePolicy; |
5227 RenderFrameImpl::PrepareRenderViewForNavigation( | 5228 RenderFrameImpl::PrepareRenderViewForNavigation( |
5228 common_params.url, request_params); | 5229 common_params.url, request_params); |
5229 | 5230 |
(...skipping 79 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
5309 request = frame_->requestForReload(load_type, override_url); | 5310 request = frame_->requestForReload(load_type, override_url); |
5310 } | 5311 } |
5311 should_load_request = true; | 5312 should_load_request = true; |
5312 } else if (is_history_navigation) { | 5313 } else if (is_history_navigation) { |
5313 // We must know the page ID of the page we are navigating back to. | 5314 // We must know the page ID of the page we are navigating back to. |
5314 DCHECK_NE(request_params.page_id, -1); | 5315 DCHECK_NE(request_params.page_id, -1); |
5315 // We must know the nav entry ID of the page we are navigating back to, | 5316 // We must know the nav entry ID of the page we are navigating back to, |
5316 // which should be the case because history navigations are routed via the | 5317 // which should be the case because history navigations are routed via the |
5317 // browser. | 5318 // browser. |
5318 DCHECK_NE(0, request_params.nav_entry_id); | 5319 DCHECK_NE(0, request_params.nav_entry_id); |
5319 scoped_ptr<HistoryEntry> entry = | 5320 std::unique_ptr<HistoryEntry> entry = |
5320 PageStateToHistoryEntry(request_params.page_state); | 5321 PageStateToHistoryEntry(request_params.page_state); |
5321 if (entry) { | 5322 if (entry) { |
5322 if (!SiteIsolationPolicy::UseSubframeNavigationEntries()) { | 5323 if (!SiteIsolationPolicy::UseSubframeNavigationEntries()) { |
5323 // By default, tell the HistoryController to go the deserialized | 5324 // By default, tell the HistoryController to go the deserialized |
5324 // HistoryEntry. This only works if all frames are in the same | 5325 // HistoryEntry. This only works if all frames are in the same |
5325 // process. | 5326 // process. |
5326 DCHECK(!frame_->parent()); | 5327 DCHECK(!frame_->parent()); |
5327 DCHECK(!browser_side_navigation); | 5328 DCHECK(!browser_side_navigation); |
5328 scoped_ptr<NavigationParams> navigation_params( | 5329 std::unique_ptr<NavigationParams> navigation_params( |
5329 new NavigationParams(*pending_navigation_params_.get())); | 5330 new NavigationParams(*pending_navigation_params_.get())); |
5330 has_history_navigation_in_frame = | 5331 has_history_navigation_in_frame = |
5331 render_view_->history_controller()->GoToEntry( | 5332 render_view_->history_controller()->GoToEntry( |
5332 frame_, std::move(entry), std::move(navigation_params), | 5333 frame_, std::move(entry), std::move(navigation_params), |
5333 cache_policy); | 5334 cache_policy); |
5334 } else { | 5335 } else { |
5335 // In --site-per-process, the browser process sends a single | 5336 // In --site-per-process, the browser process sends a single |
5336 // WebHistoryItem destined for this frame. | 5337 // WebHistoryItem destined for this frame. |
5337 // TODO(creis): Change PageState to FrameState. In the meantime, we | 5338 // TODO(creis): Change PageState to FrameState. In the meantime, we |
5338 // store the relevant frame's WebHistoryItem in the root of the | 5339 // store the relevant frame's WebHistoryItem in the root of the |
(...skipping 170 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
5509 } | 5510 } |
5510 | 5511 |
5511 void RenderFrameImpl::InitializeUserMediaClient() { | 5512 void RenderFrameImpl::InitializeUserMediaClient() { |
5512 if (!RenderThreadImpl::current()) // Will be NULL during unit tests. | 5513 if (!RenderThreadImpl::current()) // Will be NULL during unit tests. |
5513 return; | 5514 return; |
5514 | 5515 |
5515 #if defined(ENABLE_WEBRTC) | 5516 #if defined(ENABLE_WEBRTC) |
5516 DCHECK(!web_user_media_client_); | 5517 DCHECK(!web_user_media_client_); |
5517 web_user_media_client_ = new UserMediaClientImpl( | 5518 web_user_media_client_ = new UserMediaClientImpl( |
5518 this, RenderThreadImpl::current()->GetPeerConnectionDependencyFactory(), | 5519 this, RenderThreadImpl::current()->GetPeerConnectionDependencyFactory(), |
5519 make_scoped_ptr(new MediaStreamDispatcher(this))); | 5520 base::WrapUnique(new MediaStreamDispatcher(this))); |
5520 #endif | 5521 #endif |
5521 } | 5522 } |
5522 | 5523 |
5523 WebMediaPlayer* RenderFrameImpl::CreateWebMediaPlayerForMediaStream( | 5524 WebMediaPlayer* RenderFrameImpl::CreateWebMediaPlayerForMediaStream( |
5524 WebMediaPlayerClient* client, | 5525 WebMediaPlayerClient* client, |
5525 const WebString& sink_id, | 5526 const WebString& sink_id, |
5526 const WebSecurityOrigin& security_origin) { | 5527 const WebSecurityOrigin& security_origin) { |
5527 #if defined(ENABLE_WEBRTC) | 5528 #if defined(ENABLE_WEBRTC) |
5528 #if defined(OS_ANDROID) && defined(ARCH_CPU_ARMEL) | 5529 #if defined(OS_ANDROID) && defined(ARCH_CPU_ARMEL) |
5529 const bool found_neon = | 5530 const bool found_neon = |
(...skipping 11 matching lines...) Expand all Loading... |
5541 frame_, client, GetWebMediaPlayerDelegate()->AsWeakPtr(), | 5542 frame_, client, GetWebMediaPlayerDelegate()->AsWeakPtr(), |
5542 new RenderMediaLog(), CreateRendererFactory(), compositor_task_runner, | 5543 new RenderMediaLog(), CreateRendererFactory(), compositor_task_runner, |
5543 render_thread->GetMediaThreadTaskRunner(), | 5544 render_thread->GetMediaThreadTaskRunner(), |
5544 render_thread->GetWorkerTaskRunner(), render_thread->GetGpuFactories(), | 5545 render_thread->GetWorkerTaskRunner(), render_thread->GetGpuFactories(), |
5545 sink_id, security_origin); | 5546 sink_id, security_origin); |
5546 #else | 5547 #else |
5547 return NULL; | 5548 return NULL; |
5548 #endif // defined(ENABLE_WEBRTC) | 5549 #endif // defined(ENABLE_WEBRTC) |
5549 } | 5550 } |
5550 | 5551 |
5551 scoped_ptr<MediaStreamRendererFactory> | 5552 std::unique_ptr<MediaStreamRendererFactory> |
5552 RenderFrameImpl::CreateRendererFactory() { | 5553 RenderFrameImpl::CreateRendererFactory() { |
5553 scoped_ptr<MediaStreamRendererFactory> factory = | 5554 std::unique_ptr<MediaStreamRendererFactory> factory = |
5554 GetContentClient()->renderer()->CreateMediaStreamRendererFactory(); | 5555 GetContentClient()->renderer()->CreateMediaStreamRendererFactory(); |
5555 if (factory.get()) | 5556 if (factory.get()) |
5556 return factory; | 5557 return factory; |
5557 #if defined(ENABLE_WEBRTC) | 5558 #if defined(ENABLE_WEBRTC) |
5558 return scoped_ptr<MediaStreamRendererFactory>( | 5559 return std::unique_ptr<MediaStreamRendererFactory>( |
5559 new MediaStreamRendererFactoryImpl()); | 5560 new MediaStreamRendererFactoryImpl()); |
5560 #else | 5561 #else |
5561 return scoped_ptr<MediaStreamRendererFactory>( | 5562 return std::unique_ptr<MediaStreamRendererFactory>( |
5562 static_cast<MediaStreamRendererFactory*>(NULL)); | 5563 static_cast<MediaStreamRendererFactory*>(NULL)); |
5563 #endif | 5564 #endif |
5564 } | 5565 } |
5565 | 5566 |
5566 void RenderFrameImpl::PrepareRenderViewForNavigation( | 5567 void RenderFrameImpl::PrepareRenderViewForNavigation( |
5567 const GURL& url, | 5568 const GURL& url, |
5568 const RequestNavigationParams& request_params) { | 5569 const RequestNavigationParams& request_params) { |
5569 DCHECK(render_view_->webview()); | 5570 DCHECK(render_view_->webview()); |
5570 | 5571 |
5571 MaybeHandleDebugURL(url); | 5572 MaybeHandleDebugURL(url); |
(...skipping 452 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
6024 int match_count, | 6025 int match_count, |
6025 int ordinal, | 6026 int ordinal, |
6026 const WebRect& selection_rect, | 6027 const WebRect& selection_rect, |
6027 bool final_status_update) { | 6028 bool final_status_update) { |
6028 Send(new FrameHostMsg_Find_Reply(routing_id_, request_id, match_count, | 6029 Send(new FrameHostMsg_Find_Reply(routing_id_, request_id, match_count, |
6029 selection_rect, ordinal, | 6030 selection_rect, ordinal, |
6030 final_status_update)); | 6031 final_status_update)); |
6031 } | 6032 } |
6032 | 6033 |
6033 } // namespace content | 6034 } // namespace content |
OLD | NEW |