Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(253)

Side by Side Diff: net/http/http_server_properties.cc

Issue 987123002: Advertise HTTP/2 support. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
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/http/http_server_properties.h" 5 #include "net/http/http_server_properties.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/metrics/histogram.h" 8 #include "base/metrics/histogram.h"
9 #include "base/strings/stringprintf.h" 9 #include "base/strings/stringprintf.h"
10 #include "net/socket/ssl_client_socket.h" 10 #include "net/socket/ssl_client_socket.h"
11 #include "net/ssl/ssl_config.h" 11 #include "net/ssl/ssl_config.h"
12 12
13 namespace net { 13 namespace net {
14 14
15 const char kAlternateProtocolHeader[] = "Alternate-Protocol"; 15 const char kAlternateProtocolHeader[] = "Alternate-Protocol";
16 16
17 namespace { 17 namespace {
18 18
19 // The order of these strings much match the order of the enum definition 19 // The order of these strings much match the order of the enum definition
20 // for AlternateProtocol. 20 // for AlternateProtocol.
21 const char* const kAlternateProtocolStrings[] = { 21 const char* const kAlternateProtocolStrings[] = {
22 "npn-spdy/2", 22 "npn-spdy/2",
23 "npn-spdy/3", 23 "npn-spdy/3",
24 "npn-spdy/3.1", 24 "npn-spdy/3.1",
25 "npn-h2-14", // HTTP/2 draft-14. Called SPDY4 internally. 25 "npn-h2-14", // HTTP/2 draft-14. Called SPDY4 internally.
26 "npn-h2-15", // HTTP/2 draft-15. Called SPDY4 internally. 26 "npn-h2-15", // HTTP/2 draft-15. Called SPDY4 internally.
27 "quic" 27 "npn-h2",
28 }; 28 "quic"};
29 29
30 static_assert(arraysize(kAlternateProtocolStrings) == 30 static_assert(arraysize(kAlternateProtocolStrings) ==
31 NUM_VALID_ALTERNATE_PROTOCOLS, 31 NUM_VALID_ALTERNATE_PROTOCOLS,
32 "kAlternateProtocolStrings has incorrect size"); 32 "kAlternateProtocolStrings has incorrect size");
33 33
34 } // namespace 34 } // namespace
35 35
36 void HistogramAlternateProtocolUsage(AlternateProtocolUsage usage) { 36 void HistogramAlternateProtocolUsage(AlternateProtocolUsage usage) {
37 UMA_HISTOGRAM_ENUMERATION("Net.AlternateProtocolUsage", usage, 37 UMA_HISTOGRAM_ENUMERATION("Net.AlternateProtocolUsage", usage,
38 ALTERNATE_PROTOCOL_USAGE_MAX); 38 ALTERNATE_PROTOCOL_USAGE_MAX);
(...skipping 10 matching lines...) Expand all
49 protocol <= ALTERNATE_PROTOCOL_MAXIMUM_VALID_VERSION; 49 protocol <= ALTERNATE_PROTOCOL_MAXIMUM_VALID_VERSION;
50 } 50 }
51 51
52 const char* AlternateProtocolToString(AlternateProtocol protocol) { 52 const char* AlternateProtocolToString(AlternateProtocol protocol) {
53 switch (protocol) { 53 switch (protocol) {
54 case DEPRECATED_NPN_SPDY_2: 54 case DEPRECATED_NPN_SPDY_2:
55 case NPN_SPDY_3: 55 case NPN_SPDY_3:
56 case NPN_SPDY_3_1: 56 case NPN_SPDY_3_1:
57 case NPN_SPDY_4_14: 57 case NPN_SPDY_4_14:
58 case NPN_SPDY_4_15: 58 case NPN_SPDY_4_15:
59 case NPN_SPDY_4:
59 case QUIC: 60 case QUIC:
60 DCHECK(IsAlternateProtocolValid(protocol)); 61 DCHECK(IsAlternateProtocolValid(protocol));
61 return kAlternateProtocolStrings[ 62 return kAlternateProtocolStrings[
62 protocol - ALTERNATE_PROTOCOL_MINIMUM_VALID_VERSION]; 63 protocol - ALTERNATE_PROTOCOL_MINIMUM_VALID_VERSION];
63 case UNINITIALIZED_ALTERNATE_PROTOCOL: 64 case UNINITIALIZED_ALTERNATE_PROTOCOL:
64 return "Uninitialized"; 65 return "Uninitialized";
65 } 66 }
66 NOTREACHED(); 67 NOTREACHED();
67 return ""; 68 return "";
68 } 69 }
(...skipping 13 matching lines...) Expand all
82 case kProtoDeprecatedSPDY2: 83 case kProtoDeprecatedSPDY2:
83 return DEPRECATED_NPN_SPDY_2; 84 return DEPRECATED_NPN_SPDY_2;
84 case kProtoSPDY3: 85 case kProtoSPDY3:
85 return NPN_SPDY_3; 86 return NPN_SPDY_3;
86 case kProtoSPDY31: 87 case kProtoSPDY31:
87 return NPN_SPDY_3_1; 88 return NPN_SPDY_3_1;
88 case kProtoSPDY4_14: 89 case kProtoSPDY4_14:
89 return NPN_SPDY_4_14; 90 return NPN_SPDY_4_14;
90 case kProtoSPDY4_15: 91 case kProtoSPDY4_15:
91 return NPN_SPDY_4_15; 92 return NPN_SPDY_4_15;
93 case kProtoSPDY4:
94 return NPN_SPDY_4;
92 case kProtoQUIC1SPDY3: 95 case kProtoQUIC1SPDY3:
93 return QUIC; 96 return QUIC;
94 97
95 case kProtoUnknown: 98 case kProtoUnknown:
96 case kProtoHTTP11: 99 case kProtoHTTP11:
97 break; 100 break;
98 } 101 }
99 102
100 NOTREACHED() << "Invalid NextProto: " << next_proto; 103 NOTREACHED() << "Invalid NextProto: " << next_proto;
101 return UNINITIALIZED_ALTERNATE_PROTOCOL; 104 return UNINITIALIZED_ALTERNATE_PROTOCOL;
102 } 105 }
103 106
104 std::string AlternateProtocolInfo::ToString() const { 107 std::string AlternateProtocolInfo::ToString() const {
105 return base::StringPrintf("%d:%s p=%f%s", port, 108 return base::StringPrintf("%d:%s p=%f%s", port,
106 AlternateProtocolToString(protocol), 109 AlternateProtocolToString(protocol),
107 probability, 110 probability,
108 is_broken ? " (broken)" : ""); 111 is_broken ? " (broken)" : "");
109 } 112 }
110 113
111 // static 114 // static
112 void HttpServerProperties::ForceHTTP11(SSLConfig* ssl_config) { 115 void HttpServerProperties::ForceHTTP11(SSLConfig* ssl_config) {
113 ssl_config->next_protos.clear(); 116 ssl_config->next_protos.clear();
114 ssl_config->next_protos.push_back(kProtoHTTP11); 117 ssl_config->next_protos.push_back(kProtoHTTP11);
115 } 118 }
116 119
117 } // namespace net 120 } // namespace net
OLDNEW
« no previous file with comments | « net/http/http_server_properties.h ('k') | net/http/http_stream_factory_impl_request_unittest.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698