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

Side by Side Diff: net/http/http_server_properties_impl.h

Issue 1878143005: SHP 4: Change AlternativeServiceMap to use SchemeHostPort as the key. No change to Pref data. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@SHP_3
Patch Set: fix cronet && SpdyNetworkTransactionUnittests Created 4 years, 8 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 #ifndef NET_HTTP_HTTP_SERVER_PROPERTIES_IMPL_H_ 5 #ifndef NET_HTTP_HTTP_SERVER_PROPERTIES_IMPL_H_
6 #define NET_HTTP_HTTP_SERVER_PROPERTIES_IMPL_H_ 6 #define NET_HTTP_HTTP_SERVER_PROPERTIES_IMPL_H_
7 7
8 #include <stddef.h> 8 #include <stddef.h>
9 #include <stdint.h> 9 #include <stdint.h>
10 10
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after
81 void Clear() override; 81 void Clear() override;
82 bool SupportsRequestPriority(const url::SchemeHostPort& server) override; 82 bool SupportsRequestPriority(const url::SchemeHostPort& server) override;
83 bool GetSupportsSpdy(const url::SchemeHostPort& server) override; 83 bool GetSupportsSpdy(const url::SchemeHostPort& server) override;
84 void SetSupportsSpdy(const url::SchemeHostPort& server, 84 void SetSupportsSpdy(const url::SchemeHostPort& server,
85 bool support_spdy) override; 85 bool support_spdy) override;
86 bool RequiresHTTP11(const HostPortPair& server) override; 86 bool RequiresHTTP11(const HostPortPair& server) override;
87 void SetHTTP11Required(const HostPortPair& server) override; 87 void SetHTTP11Required(const HostPortPair& server) override;
88 void MaybeForceHTTP11(const HostPortPair& server, 88 void MaybeForceHTTP11(const HostPortPair& server,
89 SSLConfig* ssl_config) override; 89 SSLConfig* ssl_config) override;
90 AlternativeServiceVector GetAlternativeServices( 90 AlternativeServiceVector GetAlternativeServices(
91 const HostPortPair& origin) override; 91 const url::SchemeHostPort& origin) override;
92 bool SetAlternativeService(const HostPortPair& origin, 92 bool SetAlternativeService(const url::SchemeHostPort& origin,
93 const AlternativeService& alternative_service, 93 const AlternativeService& alternative_service,
94 base::Time expiration) override; 94 base::Time expiration) override;
95 bool SetAlternativeServices(const HostPortPair& origin, 95 bool SetAlternativeServices(const url::SchemeHostPort& origin,
96 const AlternativeServiceInfoVector& 96 const AlternativeServiceInfoVector&
97 alternative_service_info_vector) override; 97 alternative_service_info_vector) override;
98 void MarkAlternativeServiceBroken( 98 void MarkAlternativeServiceBroken(
99 const AlternativeService& alternative_service) override; 99 const AlternativeService& alternative_service) override;
100 void MarkAlternativeServiceRecentlyBroken( 100 void MarkAlternativeServiceRecentlyBroken(
101 const AlternativeService& alternative_service) override; 101 const AlternativeService& alternative_service) override;
102 bool IsAlternativeServiceBroken( 102 bool IsAlternativeServiceBroken(
103 const AlternativeService& alternative_service) const override; 103 const AlternativeService& alternative_service) const override;
104 bool WasAlternativeServiceRecentlyBroken( 104 bool WasAlternativeServiceRecentlyBroken(
105 const AlternativeService& alternative_service) override; 105 const AlternativeService& alternative_service) override;
106 void ConfirmAlternativeService( 106 void ConfirmAlternativeService(
107 const AlternativeService& alternative_service) override; 107 const AlternativeService& alternative_service) override;
108 void ClearAlternativeServices(const HostPortPair& origin) override; 108 void ClearAlternativeServices(const url::SchemeHostPort& origin) override;
109 const AlternativeServiceMap& alternative_service_map() const override; 109 const AlternativeServiceMap& alternative_service_map() const override;
110 std::unique_ptr<base::Value> GetAlternativeServiceInfoAsValue() 110 std::unique_ptr<base::Value> GetAlternativeServiceInfoAsValue()
111 const override; 111 const override;
112 const SettingsMap& GetSpdySettings( 112 const SettingsMap& GetSpdySettings(
113 const url::SchemeHostPort& server) override; 113 const url::SchemeHostPort& server) override;
114 bool SetSpdySetting(const url::SchemeHostPort& server, 114 bool SetSpdySetting(const url::SchemeHostPort& server,
115 SpdySettingsIds id, 115 SpdySettingsIds id,
116 SpdySettingsFlags flags, 116 SpdySettingsFlags flags,
117 uint32_t value) override; 117 uint32_t value) override;
118 void ClearSpdySettings(const url::SchemeHostPort& server) override; 118 void ClearSpdySettings(const url::SchemeHostPort& server) override;
(...skipping 13 matching lines...) Expand all
132 size_t max_server_configs_stored_in_properties() const override; 132 size_t max_server_configs_stored_in_properties() const override;
133 void SetMaxServerConfigsStoredInProperties( 133 void SetMaxServerConfigsStoredInProperties(
134 size_t max_server_configs_stored_in_properties) override; 134 size_t max_server_configs_stored_in_properties) override;
135 135
136 private: 136 private:
137 friend class HttpServerPropertiesImplPeer; 137 friend class HttpServerPropertiesImplPeer;
138 138
139 // |spdy_servers_map_| has flattened representation of servers 139 // |spdy_servers_map_| has flattened representation of servers
140 // (scheme, host, port) that either support or not support SPDY protocol. 140 // (scheme, host, port) that either support or not support SPDY protocol.
141 typedef base::MRUCache<std::string, bool> SpdyServersMap; 141 typedef base::MRUCache<std::string, bool> SpdyServersMap;
142 typedef std::map<HostPortPair, HostPortPair> CanonicalHostMap; 142 typedef std::map<url::SchemeHostPort, url::SchemeHostPort> CanonicalHostMap;
143 typedef std::vector<std::string> CanonicalSufficList; 143 typedef std::vector<std::string> CanonicalSufficList;
144 typedef std::set<HostPortPair> Http11ServerHostPortSet; 144 typedef std::set<HostPortPair> Http11ServerHostPortSet;
145 145
146 // Linked hash map from AlternativeService to expiration time. This container 146 // Linked hash map from AlternativeService to expiration time. This container
147 // is a queue with O(1) enqueue and dequeue, and a hash_map with O(1) lookup 147 // is a queue with O(1) enqueue and dequeue, and a hash_map with O(1) lookup
148 // at the same time. 148 // at the same time.
149 typedef linked_hash_map<AlternativeService, 149 typedef linked_hash_map<AlternativeService,
150 base::TimeTicks, 150 base::TimeTicks,
151 AlternativeServiceHash> 151 AlternativeServiceHash>
152 BrokenAlternativeServices; 152 BrokenAlternativeServices;
153 // Map to the number of times each alternative service has been marked broken. 153 // Map to the number of times each alternative service has been marked broken.
154 typedef std::map<AlternativeService, int> RecentlyBrokenAlternativeServices; 154 typedef std::map<AlternativeService, int> RecentlyBrokenAlternativeServices;
155 155
156 // Return the iterator for |server|, or for its canonical host, or end. 156 // Return the iterator for |server|, or for its canonical host, or end.
157 AlternativeServiceMap::const_iterator GetAlternateProtocolIterator( 157 AlternativeServiceMap::const_iterator GetAlternateProtocolIterator(
158 const HostPortPair& server); 158 const url::SchemeHostPort& server);
159 159
160 // Return the canonical host for |server|, or end if none exists. 160 // Return the canonical host for |server|, or end if none exists.
161 CanonicalHostMap::const_iterator GetCanonicalHost(HostPortPair server) const; 161 CanonicalHostMap::const_iterator GetCanonicalHost(
162 const url::SchemeHostPort& server) const;
162 163
163 void RemoveCanonicalHost(const HostPortPair& server); 164 // Remove the cononical host for |server| if |server| is the value in the map.
165 void RemoveCanonicalHost(const url::SchemeHostPort& server);
164 void ExpireBrokenAlternateProtocolMappings(); 166 void ExpireBrokenAlternateProtocolMappings();
165 void ScheduleBrokenAlternateProtocolMappingsExpiration(); 167 void ScheduleBrokenAlternateProtocolMappingsExpiration();
166 168
167 SpdyServersMap spdy_servers_map_; 169 SpdyServersMap spdy_servers_map_;
168 Http11ServerHostPortSet http11_servers_; 170 Http11ServerHostPortSet http11_servers_;
169 171
170 AlternativeServiceMap alternative_service_map_; 172 AlternativeServiceMap alternative_service_map_;
171 BrokenAlternativeServices broken_alternative_services_; 173 BrokenAlternativeServices broken_alternative_services_;
172 // Class invariant: Every alternative service in broken_alternative_services_ 174 // Class invariant: Every alternative service in broken_alternative_services_
173 // must also be in recently_broken_alternative_services_. 175 // must also be in recently_broken_alternative_services_.
174 RecentlyBrokenAlternativeServices recently_broken_alternative_services_; 176 RecentlyBrokenAlternativeServices recently_broken_alternative_services_;
175 177
176 IPAddress last_quic_address_; 178 IPAddress last_quic_address_;
177 SpdySettingsMap spdy_settings_map_; 179 SpdySettingsMap spdy_settings_map_;
178 ServerNetworkStatsMap server_network_stats_map_; 180 ServerNetworkStatsMap server_network_stats_map_;
179 // Contains a map of servers which could share the same alternate protocol. 181 // Contains a map of servers which could share the same alternate protocol.
180 // Map from a Canonical host/port (host is some postfix of host names) to an 182 // Map from a Canonical scheme/host/port (host is some postfix of host names)
181 // actual origin, which has a plausible alternate protocol mapping. 183 // to an actual origin, which has a plausible alternate protocol mapping.
182 CanonicalHostMap canonical_host_to_origin_map_; 184 CanonicalHostMap canonical_host_to_origin_map_;
183 // Contains list of suffixes (for exmaple ".c.youtube.com", 185 // Contains list of suffixes (for exmaple ".c.youtube.com",
184 // ".googlevideo.com", ".googleusercontent.com") of canonical hostnames. 186 // ".googlevideo.com", ".googleusercontent.com") of canonical hostnames.
185 CanonicalSufficList canonical_suffixes_; 187 CanonicalSufficList canonical_suffixes_;
186 188
187 QuicServerInfoMap quic_server_info_map_; 189 QuicServerInfoMap quic_server_info_map_;
188 size_t max_server_configs_stored_in_properties_; 190 size_t max_server_configs_stored_in_properties_;
189 191
190 base::WeakPtrFactory<HttpServerPropertiesImpl> weak_ptr_factory_; 192 base::WeakPtrFactory<HttpServerPropertiesImpl> weak_ptr_factory_;
191 193
192 DISALLOW_COPY_AND_ASSIGN(HttpServerPropertiesImpl); 194 DISALLOW_COPY_AND_ASSIGN(HttpServerPropertiesImpl);
193 }; 195 };
194 196
195 } // namespace net 197 } // namespace net
196 198
197 #endif // NET_HTTP_HTTP_SERVER_PROPERTIES_IMPL_H_ 199 #endif // NET_HTTP_HTTP_SERVER_PROPERTIES_IMPL_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698