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 "net/quic/quic_stream_factory.h" | 5 #include "net/quic/quic_stream_factory.h" |
6 | 6 |
7 #include <set> | 7 #include <set> |
8 | 8 |
9 #include "base/cpu.h" | 9 #include "base/cpu.h" |
10 #include "base/message_loop/message_loop.h" | 10 #include "base/message_loop/message_loop.h" |
(...skipping 451 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
462 const std::string& user_agent_id, | 462 const std::string& user_agent_id, |
463 const QuicVersionVector& supported_versions, | 463 const QuicVersionVector& supported_versions, |
464 bool enable_port_selection, | 464 bool enable_port_selection, |
465 bool enable_pacing, | 465 bool enable_pacing, |
466 bool enable_time_based_loss_detection, | 466 bool enable_time_based_loss_detection, |
467 const QuicTagVector& connection_options) | 467 const QuicTagVector& connection_options) |
468 : require_confirmation_(true), | 468 : require_confirmation_(true), |
469 host_resolver_(host_resolver), | 469 host_resolver_(host_resolver), |
470 client_socket_factory_(client_socket_factory), | 470 client_socket_factory_(client_socket_factory), |
471 http_server_properties_(http_server_properties), | 471 http_server_properties_(http_server_properties), |
| 472 transport_security_state_(transport_security_state), |
472 quic_server_info_factory_(NULL), | 473 quic_server_info_factory_(NULL), |
473 quic_crypto_client_stream_factory_(quic_crypto_client_stream_factory), | 474 quic_crypto_client_stream_factory_(quic_crypto_client_stream_factory), |
474 random_generator_(random_generator), | 475 random_generator_(random_generator), |
475 clock_(clock), | 476 clock_(clock), |
476 max_packet_length_(max_packet_length), | 477 max_packet_length_(max_packet_length), |
477 config_(InitializeQuicConfig(enable_pacing, | 478 config_(InitializeQuicConfig(enable_pacing, |
478 enable_time_based_loss_detection, | 479 enable_time_based_loss_detection, |
479 connection_options)), | 480 connection_options)), |
480 supported_versions_(supported_versions), | 481 supported_versions_(supported_versions), |
481 enable_port_selection_(enable_port_selection), | 482 enable_port_selection_(enable_port_selection), |
482 port_seed_(random_generator_->RandUint64()), | 483 port_seed_(random_generator_->RandUint64()), |
483 weak_factory_(this) { | 484 weak_factory_(this) { |
| 485 DCHECK(transport_security_state_); |
484 crypto_config_.SetDefaults(); | 486 crypto_config_.SetDefaults(); |
485 crypto_config_.set_user_agent_id(user_agent_id); | 487 crypto_config_.set_user_agent_id(user_agent_id); |
486 crypto_config_.AddCanonicalSuffix(".c.youtube.com"); | 488 crypto_config_.AddCanonicalSuffix(".c.youtube.com"); |
487 crypto_config_.AddCanonicalSuffix(".googlevideo.com"); | 489 crypto_config_.AddCanonicalSuffix(".googlevideo.com"); |
488 crypto_config_.SetProofVerifier( | 490 crypto_config_.SetProofVerifier( |
489 new ProofVerifierChromium(cert_verifier, transport_security_state)); | 491 new ProofVerifierChromium(cert_verifier, transport_security_state)); |
490 crypto_config_.SetChannelIDSource( | 492 crypto_config_.SetChannelIDSource( |
491 new ChannelIDSourceChromium(channel_id_service)); | 493 new ChannelIDSourceChromium(channel_id_service)); |
492 base::CPU cpu; | 494 base::CPU cpu; |
493 if (cpu.has_aesni() && cpu.has_avx()) | 495 if (cpu.has_aesni() && cpu.has_avx()) |
(...skipping 360 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
854 const HttpServerProperties::NetworkStats* stats = | 856 const HttpServerProperties::NetworkStats* stats = |
855 http_server_properties_->GetServerNetworkStats( | 857 http_server_properties_->GetServerNetworkStats( |
856 server_id.host_port_pair()); | 858 server_id.host_port_pair()); |
857 if (stats != NULL) { | 859 if (stats != NULL) { |
858 config.SetInitialRoundTripTimeUsToSend(stats->srtt.InMicroseconds()); | 860 config.SetInitialRoundTripTimeUsToSend(stats->srtt.InMicroseconds()); |
859 } | 861 } |
860 } | 862 } |
861 | 863 |
862 *session = new QuicClientSession( | 864 *session = new QuicClientSession( |
863 connection, socket.Pass(), writer.Pass(), this, | 865 connection, socket.Pass(), writer.Pass(), this, |
864 quic_crypto_client_stream_factory_, server_info.Pass(), server_id, | 866 quic_crypto_client_stream_factory_, transport_security_state_, |
865 config, &crypto_config_, | 867 server_info.Pass(), server_id, config, &crypto_config_, |
866 base::MessageLoop::current()->message_loop_proxy().get(), | 868 base::MessageLoop::current()->message_loop_proxy().get(), |
867 net_log.net_log()); | 869 net_log.net_log()); |
868 (*session)->InitializeSession(); | 870 (*session)->InitializeSession(); |
869 all_sessions_[*session] = server_id; // owning pointer | 871 all_sessions_[*session] = server_id; // owning pointer |
870 return OK; | 872 return OK; |
871 } | 873 } |
872 | 874 |
873 bool QuicStreamFactory::HasActiveJob(const QuicServerId& key) const { | 875 bool QuicStreamFactory::HasActiveJob(const QuicServerId& key) const { |
874 return ContainsKey(active_jobs_, key); | 876 return ContainsKey(active_jobs_, key); |
875 } | 877 } |
(...skipping 84 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
960 http_server_properties_->ClearAlternateProtocol(server); | 962 http_server_properties_->ClearAlternateProtocol(server); |
961 http_server_properties_->SetAlternateProtocol( | 963 http_server_properties_->SetAlternateProtocol( |
962 server, alternate.port, alternate.protocol, 1); | 964 server, alternate.port, alternate.protocol, 1); |
963 DCHECK_EQ(QUIC, | 965 DCHECK_EQ(QUIC, |
964 http_server_properties_->GetAlternateProtocol(server).protocol); | 966 http_server_properties_->GetAlternateProtocol(server).protocol); |
965 DCHECK(http_server_properties_->WasAlternateProtocolRecentlyBroken( | 967 DCHECK(http_server_properties_->WasAlternateProtocolRecentlyBroken( |
966 server)); | 968 server)); |
967 } | 969 } |
968 | 970 |
969 } // namespace net | 971 } // namespace net |
OLD | NEW |