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 "components/cronet/android/cronet_url_request_context_adapter.h" | 5 #include "components/cronet/android/cronet_url_request_context_adapter.h" |
6 | 6 |
7 #include <limits.h> | 7 #include <limits.h> |
8 #include <stddef.h> | 8 #include <stddef.h> |
9 #include <stdint.h> | 9 #include <stdint.h> |
10 | 10 |
(...skipping 29 matching lines...) Expand all Loading... |
40 #include "net/base/logging_network_change_observer.h" | 40 #include "net/base/logging_network_change_observer.h" |
41 #include "net/base/net_errors.h" | 41 #include "net/base/net_errors.h" |
42 #include "net/base/network_delegate_impl.h" | 42 #include "net/base/network_delegate_impl.h" |
43 #include "net/base/url_util.h" | 43 #include "net/base/url_util.h" |
44 #include "net/cert/cert_verifier.h" | 44 #include "net/cert/cert_verifier.h" |
45 #include "net/cookies/cookie_monster.h" | 45 #include "net/cookies/cookie_monster.h" |
46 #include "net/http/http_auth_handler_factory.h" | 46 #include "net/http/http_auth_handler_factory.h" |
47 #include "net/http/http_server_properties_manager.h" | 47 #include "net/http/http_server_properties_manager.h" |
48 #include "net/log/write_to_file_net_log_observer.h" | 48 #include "net/log/write_to_file_net_log_observer.h" |
49 #include "net/nqe/external_estimate_provider.h" | 49 #include "net/nqe/external_estimate_provider.h" |
| 50 #include "net/nqe/network_quality_estimator.h" |
50 #include "net/proxy/proxy_config_service_android.h" | 51 #include "net/proxy/proxy_config_service_android.h" |
51 #include "net/proxy/proxy_service.h" | 52 #include "net/proxy/proxy_service.h" |
52 #include "net/sdch/sdch_owner.h" | 53 #include "net/sdch/sdch_owner.h" |
53 #include "net/ssl/channel_id_service.h" | 54 #include "net/ssl/channel_id_service.h" |
54 #include "net/url_request/url_request_context.h" | 55 #include "net/url_request/url_request_context.h" |
55 #include "net/url_request/url_request_context_builder.h" | 56 #include "net/url_request/url_request_context_builder.h" |
56 #include "net/url_request/url_request_interceptor.h" | 57 #include "net/url_request/url_request_interceptor.h" |
57 | 58 |
58 #if defined(DATA_REDUCTION_PROXY_SUPPORT) | 59 #if defined(DATA_REDUCTION_PROXY_SUPPORT) |
59 #include "components/cronet/android/cronet_data_reduction_proxy.h" | 60 #include "components/cronet/android/cronet_data_reduction_proxy.h" |
(...skipping 353 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
413 // android ProxyConfigServices. | 414 // android ProxyConfigServices. |
414 android_proxy_config_service->set_exclude_pac_url(true); | 415 android_proxy_config_service->set_exclude_pac_url(true); |
415 GetNetworkTaskRunner()->PostTask( | 416 GetNetworkTaskRunner()->PostTask( |
416 FROM_HERE, | 417 FROM_HERE, |
417 base::Bind(&CronetURLRequestContextAdapter::InitializeOnNetworkThread, | 418 base::Bind(&CronetURLRequestContextAdapter::InitializeOnNetworkThread, |
418 base::Unretained(this), base::Passed(&context_config_), | 419 base::Unretained(this), base::Passed(&context_config_), |
419 jcaller_ref)); | 420 jcaller_ref)); |
420 } | 421 } |
421 | 422 |
422 void CronetURLRequestContextAdapter:: | 423 void CronetURLRequestContextAdapter:: |
423 EnableNetworkQualityEstimatorOnNetworkThread(bool use_local_host_requests, | 424 ConfigureNetworkQualityEstimatorOnNetworkThreadForTesting( |
424 bool use_smaller_responses) { | 425 bool use_local_host_requests, |
| 426 bool use_smaller_responses) { |
| 427 DCHECK(GetNetworkTaskRunner()->BelongsToCurrentThread()); |
| 428 network_quality_estimator_->SetUseLocalHostRequestsForTesting( |
| 429 use_local_host_requests); |
| 430 network_quality_estimator_->SetUseSmallResponsesForTesting( |
| 431 use_smaller_responses); |
| 432 } |
| 433 |
| 434 void CronetURLRequestContextAdapter::ConfigureNetworkQualityEstimatorForTesting( |
| 435 JNIEnv* env, |
| 436 const JavaParamRef<jobject>& jcaller, |
| 437 jboolean use_local_host_requests, |
| 438 jboolean use_smaller_responses) { |
| 439 PostTaskToNetworkThread( |
| 440 FROM_HERE, |
| 441 base::Bind(&CronetURLRequestContextAdapter:: |
| 442 ConfigureNetworkQualityEstimatorOnNetworkThreadForTesting, |
| 443 base::Unretained(this), use_local_host_requests, |
| 444 use_smaller_responses)); |
| 445 } |
| 446 |
| 447 void CronetURLRequestContextAdapter:: |
| 448 EnableNetworkQualityEstimatorOnNetworkThread() { |
425 DCHECK(GetNetworkTaskRunner()->BelongsToCurrentThread()); | 449 DCHECK(GetNetworkTaskRunner()->BelongsToCurrentThread()); |
426 DCHECK(!network_quality_estimator_); | 450 DCHECK(!network_quality_estimator_); |
427 network_quality_estimator_.reset(new net::NetworkQualityEstimator( | 451 network_quality_estimator_.reset(new net::NetworkQualityEstimator( |
428 std::unique_ptr<net::ExternalEstimateProvider>(), | 452 std::unique_ptr<net::ExternalEstimateProvider>(), |
429 std::map<std::string, std::string>(), use_local_host_requests, | 453 std::map<std::string, std::string>())); |
430 use_smaller_responses)); | |
431 context_->set_network_quality_estimator(network_quality_estimator_.get()); | 454 context_->set_network_quality_estimator(network_quality_estimator_.get()); |
432 } | 455 } |
433 | 456 |
434 void CronetURLRequestContextAdapter::EnableNetworkQualityEstimator( | 457 void CronetURLRequestContextAdapter::EnableNetworkQualityEstimator( |
435 JNIEnv* env, | 458 JNIEnv* env, |
436 const JavaParamRef<jobject>& jcaller, | 459 const JavaParamRef<jobject>& jcaller) { |
437 jboolean use_local_host_requests, | |
438 jboolean use_smaller_responses) { | |
439 PostTaskToNetworkThread( | 460 PostTaskToNetworkThread( |
440 FROM_HERE, base::Bind(&CronetURLRequestContextAdapter:: | 461 FROM_HERE, base::Bind(&CronetURLRequestContextAdapter:: |
441 EnableNetworkQualityEstimatorOnNetworkThread, | 462 EnableNetworkQualityEstimatorOnNetworkThread, |
442 base::Unretained(this), use_local_host_requests, | 463 base::Unretained(this))); |
443 use_smaller_responses)); | |
444 } | 464 } |
445 | 465 |
446 void CronetURLRequestContextAdapter::ProvideRTTObservationsOnNetworkThread( | 466 void CronetURLRequestContextAdapter::ProvideRTTObservationsOnNetworkThread( |
447 bool should) { | 467 bool should) { |
448 DCHECK(GetNetworkTaskRunner()->BelongsToCurrentThread()); | 468 DCHECK(GetNetworkTaskRunner()->BelongsToCurrentThread()); |
449 if (!network_quality_estimator_) | 469 if (!network_quality_estimator_) |
450 return; | 470 return; |
451 if (should) { | 471 if (should) { |
452 network_quality_estimator_->AddRTTObserver(this); | 472 network_quality_estimator_->AddRTTObserver(this); |
453 } else { | 473 } else { |
(...skipping 110 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
564 } | 584 } |
565 | 585 |
566 // Explicitly disable the persister for Cronet to avoid persistence of dynamic | 586 // Explicitly disable the persister for Cronet to avoid persistence of dynamic |
567 // HPKP. This is a safety measure ensuring that nobody enables the persistence | 587 // HPKP. This is a safety measure ensuring that nobody enables the persistence |
568 // of HPKP by specifying transport_security_persister_path in the future. | 588 // of HPKP by specifying transport_security_persister_path in the future. |
569 context_builder.set_transport_security_persister_path(base::FilePath()); | 589 context_builder.set_transport_security_persister_path(base::FilePath()); |
570 | 590 |
571 // Disable net::CookieStore and net::ChannelIDService. | 591 // Disable net::CookieStore and net::ChannelIDService. |
572 context_builder.SetCookieAndChannelIdStores(nullptr, nullptr); | 592 context_builder.SetCookieAndChannelIdStores(nullptr, nullptr); |
573 | 593 |
| 594 if (config->enable_network_quality_estimator) { |
| 595 DCHECK(!network_quality_estimator_); |
| 596 network_quality_estimator_.reset(new net::NetworkQualityEstimator( |
| 597 std::unique_ptr<net::ExternalEstimateProvider>(), |
| 598 std::map<std::string, std::string>(), false, false)); |
| 599 // Set the socket performance watcher factory so that network quality |
| 600 // estimator is notified of socket performance metrics from TCP and QUIC. |
| 601 context_builder.set_socket_performance_watcher_factory( |
| 602 network_quality_estimator_->GetSocketPerformanceWatcherFactory()); |
| 603 } |
| 604 |
574 context_ = context_builder.Build(); | 605 context_ = context_builder.Build(); |
| 606 if (network_quality_estimator_) |
| 607 context_->set_network_quality_estimator(network_quality_estimator_.get()); |
575 | 608 |
576 if (config->load_disable_cache) | 609 if (config->load_disable_cache) |
577 default_load_flags_ |= net::LOAD_DISABLE_CACHE; | 610 default_load_flags_ |= net::LOAD_DISABLE_CACHE; |
578 | 611 |
579 if (config->enable_sdch) { | 612 if (config->enable_sdch) { |
580 DCHECK(context_->sdch_manager()); | 613 DCHECK(context_->sdch_manager()); |
581 sdch_owner_.reset( | 614 sdch_owner_.reset( |
582 new net::SdchOwner(context_->sdch_manager(), context_.get())); | 615 new net::SdchOwner(context_->sdch_manager(), context_.get())); |
583 if (json_pref_store_) { | 616 if (json_pref_store_) { |
584 sdch_owner_->EnablePersistentStorage( | 617 sdch_owner_->EnablePersistentStorage( |
(...skipping 191 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
776 jboolean jhttp2_enabled, | 809 jboolean jhttp2_enabled, |
777 jboolean jsdch_enabled, | 810 jboolean jsdch_enabled, |
778 const JavaParamRef<jstring>& jdata_reduction_proxy_key, | 811 const JavaParamRef<jstring>& jdata_reduction_proxy_key, |
779 const JavaParamRef<jstring>& jdata_reduction_proxy_primary_proxy, | 812 const JavaParamRef<jstring>& jdata_reduction_proxy_primary_proxy, |
780 const JavaParamRef<jstring>& jdata_reduction_proxy_fallback_proxy, | 813 const JavaParamRef<jstring>& jdata_reduction_proxy_fallback_proxy, |
781 const JavaParamRef<jstring>& jdata_reduction_proxy_secure_proxy_check_url, | 814 const JavaParamRef<jstring>& jdata_reduction_proxy_secure_proxy_check_url, |
782 jboolean jdisable_cache, | 815 jboolean jdisable_cache, |
783 jint jhttp_cache_mode, | 816 jint jhttp_cache_mode, |
784 jlong jhttp_cache_max_size, | 817 jlong jhttp_cache_max_size, |
785 const JavaParamRef<jstring>& jexperimental_quic_connection_options, | 818 const JavaParamRef<jstring>& jexperimental_quic_connection_options, |
786 jlong jmock_cert_verifier) { | 819 jlong jmock_cert_verifier, |
| 820 jboolean jenable_network_quality_estimator) { |
787 return reinterpret_cast<jlong>(new URLRequestContextConfig( | 821 return reinterpret_cast<jlong>(new URLRequestContextConfig( |
788 jquic_enabled, | 822 jquic_enabled, |
789 ConvertNullableJavaStringToUTF8(env, jquic_default_user_agent_id), | 823 ConvertNullableJavaStringToUTF8(env, jquic_default_user_agent_id), |
790 jhttp2_enabled, jsdch_enabled, | 824 jhttp2_enabled, jsdch_enabled, |
791 static_cast<URLRequestContextConfig::HttpCacheType>(jhttp_cache_mode), | 825 static_cast<URLRequestContextConfig::HttpCacheType>(jhttp_cache_mode), |
792 jhttp_cache_max_size, jdisable_cache, | 826 jhttp_cache_max_size, jdisable_cache, |
793 ConvertNullableJavaStringToUTF8(env, jstorage_path), | 827 ConvertNullableJavaStringToUTF8(env, jstorage_path), |
794 ConvertNullableJavaStringToUTF8(env, juser_agent), | 828 ConvertNullableJavaStringToUTF8(env, juser_agent), |
795 ConvertNullableJavaStringToUTF8(env, | 829 ConvertNullableJavaStringToUTF8(env, |
796 jexperimental_quic_connection_options), | 830 jexperimental_quic_connection_options), |
797 ConvertNullableJavaStringToUTF8(env, jdata_reduction_proxy_key), | 831 ConvertNullableJavaStringToUTF8(env, jdata_reduction_proxy_key), |
798 ConvertNullableJavaStringToUTF8(env, jdata_reduction_proxy_primary_proxy), | 832 ConvertNullableJavaStringToUTF8(env, jdata_reduction_proxy_primary_proxy), |
799 ConvertNullableJavaStringToUTF8(env, | 833 ConvertNullableJavaStringToUTF8(env, |
800 jdata_reduction_proxy_fallback_proxy), | 834 jdata_reduction_proxy_fallback_proxy), |
801 ConvertNullableJavaStringToUTF8( | 835 ConvertNullableJavaStringToUTF8( |
802 env, jdata_reduction_proxy_secure_proxy_check_url), | 836 env, jdata_reduction_proxy_secure_proxy_check_url), |
803 base::WrapUnique( | 837 base::WrapUnique( |
804 reinterpret_cast<net::CertVerifier*>(jmock_cert_verifier)))); | 838 reinterpret_cast<net::CertVerifier*>(jmock_cert_verifier)), |
| 839 jenable_network_quality_estimator)); |
805 } | 840 } |
806 | 841 |
807 // Add a QUIC hint to a URLRequestContextConfig. | 842 // Add a QUIC hint to a URLRequestContextConfig. |
808 static void AddQuicHint(JNIEnv* env, | 843 static void AddQuicHint(JNIEnv* env, |
809 const JavaParamRef<jclass>& jcaller, | 844 const JavaParamRef<jclass>& jcaller, |
810 jlong jurl_request_context_config, | 845 jlong jurl_request_context_config, |
811 const JavaParamRef<jstring>& jhost, | 846 const JavaParamRef<jstring>& jhost, |
812 jint jport, | 847 jint jport, |
813 jint jalternate_port) { | 848 jint jalternate_port) { |
814 URLRequestContextConfig* config = | 849 URLRequestContextConfig* config = |
(...skipping 72 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
887 JNIEnv* env, | 922 JNIEnv* env, |
888 const JavaParamRef<jclass>& jcaller) { | 923 const JavaParamRef<jclass>& jcaller) { |
889 base::StatisticsRecorder::Initialize(); | 924 base::StatisticsRecorder::Initialize(); |
890 std::vector<uint8_t> data; | 925 std::vector<uint8_t> data; |
891 if (!HistogramManager::GetInstance()->GetDeltas(&data)) | 926 if (!HistogramManager::GetInstance()->GetDeltas(&data)) |
892 return ScopedJavaLocalRef<jbyteArray>(); | 927 return ScopedJavaLocalRef<jbyteArray>(); |
893 return base::android::ToJavaByteArray(env, &data[0], data.size()); | 928 return base::android::ToJavaByteArray(env, &data[0], data.size()); |
894 } | 929 } |
895 | 930 |
896 } // namespace cronet | 931 } // namespace cronet |
OLD | NEW |