OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 "chrome/browser/io_thread.h" | 5 #include "chrome/browser/io_thread.h" |
6 | 6 |
7 #include <vector> | 7 #include <vector> |
8 | 8 |
9 #include "base/base64.h" | 9 #include "base/base64.h" |
10 #include "base/bind.h" | 10 #include "base/bind.h" |
11 #include "base/bind_helpers.h" | 11 #include "base/bind_helpers.h" |
12 #include "base/command_line.h" | 12 #include "base/command_line.h" |
13 #include "base/compiler_specific.h" | 13 #include "base/compiler_specific.h" |
14 #include "base/debug/leak_tracker.h" | 14 #include "base/debug/leak_tracker.h" |
15 #include "base/environment.h" | |
15 #include "base/logging.h" | 16 #include "base/logging.h" |
16 #include "base/metrics/field_trial.h" | 17 #include "base/metrics/field_trial.h" |
17 #include "base/prefs/pref_registry_simple.h" | 18 #include "base/prefs/pref_registry_simple.h" |
18 #include "base/prefs/pref_service.h" | 19 #include "base/prefs/pref_service.h" |
19 #include "base/profiler/scoped_tracker.h" | 20 #include "base/profiler/scoped_tracker.h" |
20 #include "base/stl_util.h" | 21 #include "base/stl_util.h" |
21 #include "base/strings/string_number_conversions.h" | 22 #include "base/strings/string_number_conversions.h" |
22 #include "base/strings/string_piece.h" | 23 #include "base/strings/string_piece.h" |
23 #include "base/strings/string_split.h" | 24 #include "base/strings/string_split.h" |
24 #include "base/strings/string_util.h" | 25 #include "base/strings/string_util.h" |
(...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
73 #include "net/http/http_auth_filter.h" | 74 #include "net/http/http_auth_filter.h" |
74 #include "net/http/http_auth_handler_factory.h" | 75 #include "net/http/http_auth_handler_factory.h" |
75 #include "net/http/http_network_layer.h" | 76 #include "net/http/http_network_layer.h" |
76 #include "net/http/http_server_properties_impl.h" | 77 #include "net/http/http_server_properties_impl.h" |
77 #include "net/proxy/proxy_config_service.h" | 78 #include "net/proxy/proxy_config_service.h" |
78 #include "net/proxy/proxy_script_fetcher_impl.h" | 79 #include "net/proxy/proxy_script_fetcher_impl.h" |
79 #include "net/proxy/proxy_service.h" | 80 #include "net/proxy/proxy_service.h" |
80 #include "net/quic/crypto/crypto_protocol.h" | 81 #include "net/quic/crypto/crypto_protocol.h" |
81 #include "net/quic/quic_protocol.h" | 82 #include "net/quic/quic_protocol.h" |
82 #include "net/quic/quic_utils.h" | 83 #include "net/quic/quic_utils.h" |
84 #include "net/socket/ssl_client_socket.h" | |
83 #include "net/socket/tcp_client_socket.h" | 85 #include "net/socket/tcp_client_socket.h" |
84 #include "net/spdy/spdy_session.h" | 86 #include "net/spdy/spdy_session.h" |
85 #include "net/ssl/channel_id_service.h" | 87 #include "net/ssl/channel_id_service.h" |
86 #include "net/ssl/default_channel_id_store.h" | 88 #include "net/ssl/default_channel_id_store.h" |
87 #include "net/url_request/data_protocol_handler.h" | 89 #include "net/url_request/data_protocol_handler.h" |
88 #include "net/url_request/file_protocol_handler.h" | 90 #include "net/url_request/file_protocol_handler.h" |
89 #include "net/url_request/ftp_protocol_handler.h" | 91 #include "net/url_request/ftp_protocol_handler.h" |
90 #include "net/url_request/static_http_user_agent_settings.h" | 92 #include "net/url_request/static_http_user_agent_settings.h" |
91 #include "net/url_request/url_fetcher.h" | 93 #include "net/url_request/url_fetcher.h" |
92 #include "net/url_request/url_request_backoff_manager.h" | 94 #include "net/url_request/url_request_backoff_manager.h" |
(...skipping 452 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
545 net::SetMessageLoopForNSSHttpIO(); | 547 net::SetMessageLoopForNSSHttpIO(); |
546 #endif | 548 #endif |
547 | 549 |
548 // TODO(erikchen): Remove ScopedTracker below once http://crbug.com/466432 | 550 // TODO(erikchen): Remove ScopedTracker below once http://crbug.com/466432 |
549 // is fixed. | 551 // is fixed. |
550 tracked_objects::ScopedTracker tracking_profile2( | 552 tracked_objects::ScopedTracker tracking_profile2( |
551 FROM_HERE_WITH_EXPLICIT_FUNCTION( | 553 FROM_HERE_WITH_EXPLICIT_FUNCTION( |
552 "466432 IOThread::InitAsync::CommandLineForCurrentProcess")); | 554 "466432 IOThread::InitAsync::CommandLineForCurrentProcess")); |
553 const base::CommandLine& command_line = | 555 const base::CommandLine& command_line = |
554 *base::CommandLine::ForCurrentProcess(); | 556 *base::CommandLine::ForCurrentProcess(); |
555 | 557 |
davidben
2015/10/15 16:46:00
Optional: I probably wouldn't bother trying to log
Zhongyi Shi
2015/10/15 19:03:05
Done.
| |
558 std::string env_ssl_keylog_file; | |
559 scoped_ptr<base::Environment> env(base::Environment::Create()); | |
560 env->GetVar("SSLKEYLOGFILE", &env_ssl_keylog_file); | |
561 | |
562 std::string flag_ssl_keylog_file; | |
563 if (command_line.HasSwitch(switches::kSSLKeyLogFile)) { | |
564 flag_ssl_keylog_file = command_line.GetSwitchValueASCII( | |
565 switches::kSSLKeyLogFile); | |
566 if (flag_ssl_keylog_file.empty()) { | |
567 LOG(WARNING) << "ssl-key-log-file argument missing, ignored."; | |
568 } | |
569 } | |
570 | |
571 if (!flag_ssl_keylog_file.empty() && !env_ssl_keylog_file.empty()) { | |
572 LOG(WARNING) << | |
573 "SSLKEYLOGFILE and ssl-key-log-file both set, SSLKEYLOGFILE ignored"; | |
574 } | |
575 | |
576 const std::string ssl_keylog_file = | |
Bryan McQuade
2015/10/15 02:09:47
if possible, this should be const std::string& to
| |
577 !flag_ssl_keylog_file.empty() ? flag_ssl_keylog_file : env_ssl_keylog_file; | |
578 | |
579 if (!ssl_keylog_file.empty()) { | |
580 #if defined(USE_OPENSSL) | |
davidben
2015/10/15 16:46:00
You can remove this. I'm pretty sure anything usin
Zhongyi Shi
2015/10/15 19:03:05
Done.
| |
581 net::SSLClientSocket::SetSSLKeyLogFile(ssl_keylog_file); | |
582 #else | |
583 DVLOG(1) << "Platform does not support openssl"; | |
584 #endif | |
585 } | |
586 | |
556 DCHECK(!globals_); | 587 DCHECK(!globals_); |
557 globals_ = new Globals; | 588 globals_ = new Globals; |
558 | 589 |
559 // Add an observer that will emit network change events to the ChromeNetLog. | 590 // Add an observer that will emit network change events to the ChromeNetLog. |
560 // Assuming NetworkChangeNotifier dispatches in FIFO order, we should be | 591 // Assuming NetworkChangeNotifier dispatches in FIFO order, we should be |
561 // logging the network change before other IO thread consumers respond to it. | 592 // logging the network change before other IO thread consumers respond to it. |
562 network_change_observer_.reset( | 593 network_change_observer_.reset( |
563 new LoggingNetworkChangeObserver(net_log_)); | 594 new LoggingNetworkChangeObserver(net_log_)); |
564 | 595 |
565 // Setup the HistogramWatcher to run on the IO thread. | 596 // Setup the HistogramWatcher to run on the IO thread. |
(...skipping 1026 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1592 globals->proxy_script_fetcher_url_request_job_factory = job_factory.Pass(); | 1623 globals->proxy_script_fetcher_url_request_job_factory = job_factory.Pass(); |
1593 | 1624 |
1594 context->set_job_factory( | 1625 context->set_job_factory( |
1595 globals->proxy_script_fetcher_url_request_job_factory.get()); | 1626 globals->proxy_script_fetcher_url_request_job_factory.get()); |
1596 | 1627 |
1597 // TODO(rtenneti): We should probably use HttpServerPropertiesManager for the | 1628 // TODO(rtenneti): We should probably use HttpServerPropertiesManager for the |
1598 // system URLRequestContext too. There's no reason this should be tied to a | 1629 // system URLRequestContext too. There's no reason this should be tied to a |
1599 // profile. | 1630 // profile. |
1600 return context; | 1631 return context; |
1601 } | 1632 } |
OLD | NEW |