[email protected] | 39c48fc | 2012-03-12 18:42:12 | [diff] [blame] | 1 | // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
[email protected] | 17291a02 | 2011-10-10 07:32:53 | [diff] [blame] | 2 | // Use of this source code is governed by a BSD-style license that can be |
| 3 | // found in the LICENSE file. |
| 4 | |
| 5 | #include "net/http/http_server_properties.h" |
| 6 | |
| 7 | #include "base/logging.h" |
asvitkine | c3c9372 | 2015-06-17 14:48:37 | [diff] [blame] | 8 | #include "base/metrics/histogram_macros.h" |
[email protected] | 125ef48 | 2013-06-11 18:32:47 | [diff] [blame] | 9 | #include "base/strings/stringprintf.h" |
zhongyi | e537a00 | 2017-06-27 16:48:21 | [diff] [blame] | 10 | #include "net/http/http_network_session.h" |
bnc | facdd85 | 2015-01-09 19:22:54 | [diff] [blame] | 11 | #include "net/socket/ssl_client_socket.h" |
| 12 | #include "net/ssl/ssl_config.h" |
[email protected] | 17291a02 | 2011-10-10 07:32:53 | [diff] [blame] | 13 | |
| 14 | namespace net { |
| 15 | |
zhongyi | 7935a55 | 2016-09-27 00:57:23 | [diff] [blame] | 16 | namespace { |
| 17 | |
| 18 | enum AlternativeProxyUsage { |
| 19 | // Alternative Proxy was used without racing a normal connection. |
| 20 | ALTERNATIVE_PROXY_USAGE_NO_RACE = 0, |
| 21 | // Alternative Proxy was used by winning a race with a normal connection. |
| 22 | ALTERNATIVE_PROXY_USAGE_WON_RACE = 1, |
| 23 | // Alternative Proxy was not used by losing a race with a normal connection. |
| 24 | ALTERNATIVE_PROXY_USAGE_LOST_RACE = 2, |
| 25 | // Maximum value for the enum. |
| 26 | ALTERNATIVE_PROXY_USAGE_MAX, |
| 27 | }; |
| 28 | |
| 29 | AlternativeProxyUsage ConvertProtocolUsageToProxyUsage( |
| 30 | AlternateProtocolUsage usage) { |
| 31 | switch (usage) { |
| 32 | case ALTERNATE_PROTOCOL_USAGE_NO_RACE: |
| 33 | return ALTERNATIVE_PROXY_USAGE_NO_RACE; |
| 34 | case ALTERNATE_PROTOCOL_USAGE_WON_RACE: |
| 35 | return ALTERNATIVE_PROXY_USAGE_WON_RACE; |
| 36 | case ALTERNATE_PROTOCOL_USAGE_LOST_RACE: |
| 37 | return ALTERNATIVE_PROXY_USAGE_LOST_RACE; |
| 38 | default: |
| 39 | NOTREACHED(); |
| 40 | return ALTERNATIVE_PROXY_USAGE_MAX; |
| 41 | } |
| 42 | } |
| 43 | |
bnc | d479b3c | 2017-05-24 18:54:53 | [diff] [blame] | 44 | } // anonymous namespace |
zhongyi | 7935a55 | 2016-09-27 00:57:23 | [diff] [blame] | 45 | |
bnc | c958faa | 2015-07-31 18:14:52 | [diff] [blame] | 46 | const char kAlternativeServiceHeader[] = "Alt-Svc"; |
[email protected] | 88a33262 | 2013-07-30 07:13:32 | [diff] [blame] | 47 | |
zhongyi | 7935a55 | 2016-09-27 00:57:23 | [diff] [blame] | 48 | void HistogramAlternateProtocolUsage(AlternateProtocolUsage usage, |
| 49 | bool proxy_server_used) { |
| 50 | if (proxy_server_used) { |
| 51 | DCHECK_LE(usage, ALTERNATE_PROTOCOL_USAGE_LOST_RACE); |
| 52 | UMA_HISTOGRAM_ENUMERATION("Net.QuicAlternativeProxy.Usage", |
| 53 | ConvertProtocolUsageToProxyUsage(usage), |
| 54 | ALTERNATIVE_PROXY_USAGE_MAX); |
| 55 | } else { |
| 56 | UMA_HISTOGRAM_ENUMERATION("Net.AlternateProtocolUsage", usage, |
| 57 | ALTERNATE_PROTOCOL_USAGE_MAX); |
| 58 | } |
[email protected] | db9bfea | 2014-04-11 18:51:39 | [diff] [blame] | 59 | } |
| 60 | |
[email protected] | 7b33037f | 2014-04-11 23:00:28 | [diff] [blame] | 61 | void HistogramBrokenAlternateProtocolLocation( |
| 62 | BrokenAlternateProtocolLocation location){ |
| 63 | UMA_HISTOGRAM_ENUMERATION("Net.AlternateProtocolBrokenLocation", location, |
| 64 | BROKEN_ALTERNATE_PROTOCOL_LOCATION_MAX); |
| 65 | } |
| 66 | |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 67 | bool IsAlternateProtocolValid(NextProto protocol) { |
bnc | 8f8225c | 2016-09-23 21:19:46 | [diff] [blame] | 68 | switch (protocol) { |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 69 | case kProtoUnknown: |
bnc | e1a722c | 2016-11-11 16:38:06 | [diff] [blame] | 70 | return false; |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 71 | case kProtoHTTP11: |
| 72 | return false; |
| 73 | case kProtoHTTP2: |
| 74 | return true; |
| 75 | case kProtoQUIC: |
| 76 | return true; |
bnc | 8f8225c | 2016-09-23 21:19:46 | [diff] [blame] | 77 | } |
| 78 | NOTREACHED(); |
| 79 | return false; |
[email protected] | 13621d6 | 2013-10-04 18:39:21 | [diff] [blame] | 80 | } |
| 81 | |
zhongyi | e537a00 | 2017-06-27 16:48:21 | [diff] [blame] | 82 | // static |
| 83 | AlternativeServiceInfo |
| 84 | AlternativeServiceInfo::CreateHttp2AlternativeServiceInfo( |
| 85 | const AlternativeService& alternative_service, |
| 86 | base::Time expiration) { |
| 87 | DCHECK_EQ(alternative_service.protocol, kProtoHTTP2); |
| 88 | return AlternativeServiceInfo(alternative_service, expiration, |
Nick Harper | 23290b8 | 2019-05-02 00:02:56 | [diff] [blame] | 89 | quic::ParsedQuicVersionVector()); |
zhongyi | e537a00 | 2017-06-27 16:48:21 | [diff] [blame] | 90 | } |
| 91 | |
| 92 | // static |
| 93 | AlternativeServiceInfo AlternativeServiceInfo::CreateQuicAlternativeServiceInfo( |
| 94 | const AlternativeService& alternative_service, |
| 95 | base::Time expiration, |
Nick Harper | 23290b8 | 2019-05-02 00:02:56 | [diff] [blame] | 96 | const quic::ParsedQuicVersionVector& advertised_versions) { |
zhongyi | e537a00 | 2017-06-27 16:48:21 | [diff] [blame] | 97 | DCHECK_EQ(alternative_service.protocol, kProtoQUIC); |
| 98 | return AlternativeServiceInfo(alternative_service, expiration, |
| 99 | advertised_versions); |
| 100 | } |
| 101 | |
zhongyi | 422ce35 | 2017-06-09 23:28:54 | [diff] [blame] | 102 | AlternativeServiceInfo::AlternativeServiceInfo() : alternative_service_() {} |
| 103 | |
Chris Watkins | 7a41d355 | 2017-12-01 02:13:27 | [diff] [blame] | 104 | AlternativeServiceInfo::~AlternativeServiceInfo() = default; |
zhongyi | e537a00 | 2017-06-27 16:48:21 | [diff] [blame] | 105 | |
zhongyi | 422ce35 | 2017-06-09 23:28:54 | [diff] [blame] | 106 | AlternativeServiceInfo::AlternativeServiceInfo( |
| 107 | const AlternativeService& alternative_service, |
zhongyi | e537a00 | 2017-06-27 16:48:21 | [diff] [blame] | 108 | base::Time expiration, |
Nick Harper | 23290b8 | 2019-05-02 00:02:56 | [diff] [blame] | 109 | const quic::ParsedQuicVersionVector& advertised_versions) |
zhongyi | e537a00 | 2017-06-27 16:48:21 | [diff] [blame] | 110 | : alternative_service_(alternative_service), expiration_(expiration) { |
| 111 | if (alternative_service_.protocol == kProtoQUIC) { |
| 112 | advertised_versions_ = advertised_versions; |
Nick Harper | 23290b8 | 2019-05-02 00:02:56 | [diff] [blame] | 113 | std::sort(advertised_versions_.begin(), advertised_versions_.end(), |
| 114 | TransportVersionLessThan); |
zhongyi | e537a00 | 2017-06-27 16:48:21 | [diff] [blame] | 115 | } |
| 116 | } |
zhongyi | 422ce35 | 2017-06-09 23:28:54 | [diff] [blame] | 117 | |
| 118 | AlternativeServiceInfo::AlternativeServiceInfo( |
| 119 | const AlternativeServiceInfo& alternative_service_info) = default; |
| 120 | |
| 121 | AlternativeServiceInfo& AlternativeServiceInfo::operator=( |
| 122 | const AlternativeServiceInfo& alternative_service_info) = default; |
| 123 | |
bnc | 4988e43 | 2015-03-31 03:06:25 | [diff] [blame] | 124 | std::string AlternativeService::ToString() const { |
bnc | 3472afd | 2016-11-17 15:27:21 | [diff] [blame] | 125 | return base::StringPrintf("%s %s:%d", NextProtoToString(protocol), |
bnc | 4988e43 | 2015-03-31 03:06:25 | [diff] [blame] | 126 | host.c_str(), port); |
| 127 | } |
| 128 | |
| 129 | std::string AlternativeServiceInfo::ToString() const { |
bnc | e4f571c | 2015-12-10 20:10:37 | [diff] [blame] | 130 | base::Time::Exploded exploded; |
zhongyi | 422ce35 | 2017-06-09 23:28:54 | [diff] [blame] | 131 | expiration_.LocalExplode(&exploded); |
rch | dc7b905 | 2016-03-17 20:51:50 | [diff] [blame] | 132 | return base::StringPrintf( |
| 133 | "%s, expires %04d-%02d-%02d %02d:%02d:%02d", |
zhongyi | 422ce35 | 2017-06-09 23:28:54 | [diff] [blame] | 134 | alternative_service_.ToString().c_str(), exploded.year, exploded.month, |
rch | dc7b905 | 2016-03-17 20:51:50 | [diff] [blame] | 135 | exploded.day_of_month, exploded.hour, exploded.minute, exploded.second); |
[email protected] | 17291a02 | 2011-10-10 07:32:53 | [diff] [blame] | 136 | } |
| 137 | |
Nick Harper | 23290b8 | 2019-05-02 00:02:56 | [diff] [blame] | 138 | // static |
| 139 | bool AlternativeServiceInfo::TransportVersionLessThan( |
| 140 | const quic::ParsedQuicVersion& lhs, |
| 141 | const quic::ParsedQuicVersion& rhs) { |
| 142 | return lhs.transport_version < rhs.transport_version; |
| 143 | } |
| 144 | |
bnc | 396d33b | 2017-04-10 16:40:18 | [diff] [blame] | 145 | std::ostream& operator<<(std::ostream& os, |
| 146 | const AlternativeService& alternative_service) { |
| 147 | os << alternative_service.ToString(); |
| 148 | return os; |
| 149 | } |
| 150 | |
bnc | facdd85 | 2015-01-09 19:22:54 | [diff] [blame] | 151 | // static |
| 152 | void HttpServerProperties::ForceHTTP11(SSLConfig* ssl_config) { |
bnc | 1f29537 | 2015-10-21 23:24:22 | [diff] [blame] | 153 | ssl_config->alpn_protos.clear(); |
| 154 | ssl_config->alpn_protos.push_back(kProtoHTTP11); |
bnc | facdd85 | 2015-01-09 19:22:54 | [diff] [blame] | 155 | } |
| 156 | |
[email protected] | 17291a02 | 2011-10-10 07:32:53 | [diff] [blame] | 157 | } // namespace net |