1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef NET_QUIC_QUIC_CONFIG_H_
6 #define NET_QUIC_QUIC_CONFIG_H_
10 #include "base/basictypes.h"
11 #include "net/quic/quic_protocol.h"
12 #include "net/quic/quic_time.h"
20 class CryptoHandshakeMessage
;
22 // Describes whether or not a given QuicTag is required or optional in the
24 enum QuicConfigPresence
{
25 // This negotiable value can be absent from the handshake message. Default
26 // value is selected as the negotiated value in such a case.
28 // This negotiable value is required in the handshake message otherwise the
29 // Process*Hello function returns an error.
33 // Whether the CryptoHandshakeMessage is from the client or server.
39 // An abstract base class that stores a value that can be sent in CHLO/SHLO
40 // message. These values can be OPTIONAL or REQUIRED, depending on |presence_|.
41 class NET_EXPORT_PRIVATE QuicConfigValue
{
43 QuicConfigValue(QuicTag tag
, QuicConfigPresence presence
);
44 virtual ~QuicConfigValue();
46 // Serialises tag name and value(s) to |out|.
47 virtual void ToHandshakeMessage(CryptoHandshakeMessage
* out
) const = 0;
49 // Selects a mutually acceptable value from those offered in |peer_hello|
50 // and those defined in the subclass.
51 virtual QuicErrorCode
ProcessPeerHello(
52 const CryptoHandshakeMessage
& peer_hello
,
54 std::string
* error_details
) = 0;
58 const QuicConfigPresence presence_
;
61 class NET_EXPORT_PRIVATE QuicNegotiableValue
: public QuicConfigValue
{
63 QuicNegotiableValue(QuicTag tag
, QuicConfigPresence presence
);
64 ~QuicNegotiableValue() override
;
66 bool negotiated() const {
71 void set_negotiated(bool negotiated
) { negotiated_
= negotiated
; }
77 class NET_EXPORT_PRIVATE QuicNegotiableUint32
: public QuicNegotiableValue
{
79 // Default and max values default to 0.
80 QuicNegotiableUint32(QuicTag name
, QuicConfigPresence presence
);
81 ~QuicNegotiableUint32() override
;
83 // Sets the maximum possible value that can be achieved after negotiation and
84 // also the default values to be assumed if PRESENCE_OPTIONAL and the *HLO msg
85 // doesn't contain a value corresponding to |name_|. |max| is serialised via
86 // ToHandshakeMessage call if |negotiated_| is false.
87 void set(uint32 max
, uint32 default_value
);
89 // Returns the value negotiated if |negotiated_| is true, otherwise returns
90 // default_value_ (used to set default values before negotiation finishes).
91 uint32
GetUint32() const;
93 // Serialises |name_| and value to |out|. If |negotiated_| is true then
94 // |negotiated_value_| is serialised, otherwise |max_value_| is serialised.
95 void ToHandshakeMessage(CryptoHandshakeMessage
* out
) const override
;
97 // Sets |negotiated_value_| to the minimum of |max_value_| and the
98 // corresponding value from |peer_hello|. If the corresponding value is
99 // missing and PRESENCE_OPTIONAL then |negotiated_value_| is set to
101 QuicErrorCode
ProcessPeerHello(const CryptoHandshakeMessage
& peer_hello
,
102 HelloType hello_type
,
103 std::string
* error_details
) override
;
107 uint32 default_value_
;
108 uint32 negotiated_value_
;
111 class NET_EXPORT_PRIVATE QuicNegotiableTag
: public QuicNegotiableValue
{
113 QuicNegotiableTag(QuicTag name
, QuicConfigPresence presence
);
114 ~QuicNegotiableTag() override
;
116 // Sets the possible values that |negotiated_tag_| can take after negotiation
117 // and the default value that |negotiated_tag_| takes if OPTIONAL and *HLO
118 // msg doesn't contain tag |name_|.
119 void set(const QuicTagVector
& possible_values
, QuicTag default_value
);
121 // Returns the negotiated tag if |negotiated_| is true, otherwise returns
122 // |default_value_| (used to set default values before negotiation finishes).
123 QuicTag
GetTag() const;
125 // Serialises |name_| and vector (either possible or negotiated) to |out|. If
126 // |negotiated_| is true then |negotiated_tag_| is serialised, otherwise
127 // |possible_values_| is serialised.
128 void ToHandshakeMessage(CryptoHandshakeMessage
* out
) const override
;
130 // Selects the tag common to both tags in |client_hello| for |name_| and
131 // |possible_values_| with preference to tag in |possible_values_|. The
132 // selected tag is set as |negotiated_tag_|.
133 QuicErrorCode
ProcessPeerHello(const CryptoHandshakeMessage
& peer_hello
,
134 HelloType hello_type
,
135 std::string
* error_details
) override
;
138 // Reads the vector corresponding to |name_| from |msg| into |out|. If the
139 // |name_| is absent in |msg| and |presence_| is set to OPTIONAL |out| is set
140 // to |possible_values_|.
141 QuicErrorCode
ReadVector(const CryptoHandshakeMessage
& msg
,
144 std::string
* error_details
) const;
146 QuicTag negotiated_tag_
;
147 QuicTagVector possible_values_
;
148 QuicTag default_value_
;
151 // Stores uint32 from CHLO or SHLO messages that are not negotiated.
152 class NET_EXPORT_PRIVATE QuicFixedUint32
: public QuicConfigValue
{
154 QuicFixedUint32(QuicTag name
, QuicConfigPresence presence
);
155 ~QuicFixedUint32() override
;
157 bool HasSendValue() const;
159 uint32
GetSendValue() const;
161 void SetSendValue(uint32 value
);
163 bool HasReceivedValue() const;
165 uint32
GetReceivedValue() const;
167 void SetReceivedValue(uint32 value
);
169 // If has_send_value is true, serialises |tag_| and |send_value_| to |out|.
170 void ToHandshakeMessage(CryptoHandshakeMessage
* out
) const override
;
172 // Sets |value_| to the corresponding value from |peer_hello_| if it exists.
173 QuicErrorCode
ProcessPeerHello(const CryptoHandshakeMessage
& peer_hello
,
174 HelloType hello_type
,
175 std::string
* error_details
) override
;
179 bool has_send_value_
;
180 uint32 receive_value_
;
181 bool has_receive_value_
;
184 // Stores tag from CHLO or SHLO messages that are not negotiated.
185 class NET_EXPORT_PRIVATE QuicFixedTagVector
: public QuicConfigValue
{
187 QuicFixedTagVector(QuicTag name
, QuicConfigPresence presence
);
188 ~QuicFixedTagVector() override
;
190 bool HasSendValues() const;
192 QuicTagVector
GetSendValues() const;
194 void SetSendValues(const QuicTagVector
& values
);
196 bool HasReceivedValues() const;
198 QuicTagVector
GetReceivedValues() const;
200 void SetReceivedValues(const QuicTagVector
& values
);
202 // If has_send_value is true, serialises |tag_vector_| and |send_value_| to
204 void ToHandshakeMessage(CryptoHandshakeMessage
* out
) const override
;
206 // Sets |receive_values_| to the corresponding value from |client_hello_| if
208 QuicErrorCode
ProcessPeerHello(const CryptoHandshakeMessage
& peer_hello
,
209 HelloType hello_type
,
210 std::string
* error_details
) override
;
213 QuicTagVector send_values_
;
214 bool has_send_values_
;
215 QuicTagVector receive_values_
;
216 bool has_receive_values_
;
219 // QuicConfig contains non-crypto configuration options that are negotiated in
220 // the crypto handshake.
221 class NET_EXPORT_PRIVATE QuicConfig
{
226 void SetConnectionOptionsToSend(const QuicTagVector
& connection_options
);
228 bool HasReceivedConnectionOptions() const;
230 QuicTagVector
ReceivedConnectionOptions() const;
232 bool HasSendConnectionOptions() const;
234 QuicTagVector
SendConnectionOptions() const;
236 void SetIdleConnectionStateLifetime(
237 QuicTime::Delta max_idle_connection_state_lifetime
,
238 QuicTime::Delta default_idle_conection_state_lifetime
);
240 QuicTime::Delta
IdleConnectionStateLifetime() const;
242 void SetSilentClose(bool silent_close
);
244 bool SilentClose() const;
246 void SetMaxStreamsPerConnection(size_t max_streams
, size_t default_streams
);
248 uint32
MaxStreamsPerConnection() const;
250 void set_max_time_before_crypto_handshake(
251 QuicTime::Delta max_time_before_crypto_handshake
) {
252 max_time_before_crypto_handshake_
= max_time_before_crypto_handshake
;
255 QuicTime::Delta
max_time_before_crypto_handshake() const {
256 return max_time_before_crypto_handshake_
;
259 void set_max_idle_time_before_crypto_handshake(
260 QuicTime::Delta max_idle_time_before_crypto_handshake
) {
261 max_idle_time_before_crypto_handshake_
=
262 max_idle_time_before_crypto_handshake
;
265 QuicTime::Delta
max_idle_time_before_crypto_handshake() const {
266 return max_idle_time_before_crypto_handshake_
;
269 void set_max_undecryptable_packets(size_t max_undecryptable_packets
) {
270 max_undecryptable_packets_
= max_undecryptable_packets
;
273 size_t max_undecryptable_packets() const {
274 return max_undecryptable_packets_
;
277 bool HasSetBytesForConnectionIdToSend() const;
279 // Sets the peer's connection id length, in bytes.
280 void SetBytesForConnectionIdToSend(uint32 bytes
);
282 bool HasReceivedBytesForConnectionId() const;
284 uint32
ReceivedBytesForConnectionId() const;
286 // Sets an estimated initial round trip time in us.
287 void SetInitialRoundTripTimeUsToSend(uint32 rtt_us
);
289 bool HasReceivedInitialRoundTripTimeUs() const;
291 uint32
ReceivedInitialRoundTripTimeUs() const;
293 bool HasInitialRoundTripTimeUsToSend() const;
295 uint32
GetInitialRoundTripTimeUsToSend() const;
297 // Sets an initial stream flow control window size to transmit to the peer.
298 void SetInitialStreamFlowControlWindowToSend(uint32 window_bytes
);
300 uint32
GetInitialStreamFlowControlWindowToSend() const;
302 bool HasReceivedInitialStreamFlowControlWindowBytes() const;
304 uint32
ReceivedInitialStreamFlowControlWindowBytes() const;
306 // Sets an initial session flow control window size to transmit to the peer.
307 void SetInitialSessionFlowControlWindowToSend(uint32 window_bytes
);
309 uint32
GetInitialSessionFlowControlWindowToSend() const;
311 bool HasReceivedInitialSessionFlowControlWindowBytes() const;
313 uint32
ReceivedInitialSessionFlowControlWindowBytes() const;
315 // Sets socket receive buffer to transmit to the peer.
316 void SetSocketReceiveBufferToSend(uint32 window_bytes
);
318 bool HasReceivedSocketReceiveBuffer() const;
320 uint32
ReceivedSocketReceiveBuffer() const;
322 bool negotiated() const;
324 // ToHandshakeMessage serialises the settings in this object as a series of
325 // tags /value pairs and adds them to |out|.
326 void ToHandshakeMessage(CryptoHandshakeMessage
* out
) const;
328 // Calls ProcessPeerHello on each negotiable parameter. On failure returns
329 // the corresponding QuicErrorCode and sets detailed error in |error_details|.
330 QuicErrorCode
ProcessPeerHello(const CryptoHandshakeMessage
& peer_hello
,
331 HelloType hello_type
,
332 std::string
* error_details
);
335 friend class test::QuicConfigPeer
;
337 // SetDefaults sets the members to sensible, default values.
340 // Configurations options that are not negotiated.
341 // Maximum time the session can be alive before crypto handshake is finished.
342 QuicTime::Delta max_time_before_crypto_handshake_
;
343 // Maximum idle time before the crypto handshake has completed.
344 QuicTime::Delta max_idle_time_before_crypto_handshake_
;
345 // Maximum number of undecryptable packets stored before CHLO/SHLO.
346 size_t max_undecryptable_packets_
;
348 // Congestion control feedback type.
349 QuicNegotiableTag congestion_feedback_
;
350 // Connection options.
351 QuicFixedTagVector connection_options_
;
352 // Idle connection state lifetime
353 QuicNegotiableUint32 idle_connection_state_lifetime_seconds_
;
354 // Whether to use silent close. Defaults to 0 (false) and is otherwise true.
355 QuicNegotiableUint32 silent_close_
;
356 // Maximum number of streams that the connection can support.
357 QuicNegotiableUint32 max_streams_per_connection_
;
358 // The number of bytes required for the connection ID.
359 QuicFixedUint32 bytes_for_connection_id_
;
360 // Initial round trip time estimate in microseconds.
361 QuicFixedUint32 initial_round_trip_time_us_
;
363 // Initial stream flow control receive window in bytes.
364 QuicFixedUint32 initial_stream_flow_control_window_bytes_
;
365 // Initial session flow control receive window in bytes.
366 QuicFixedUint32 initial_session_flow_control_window_bytes_
;
368 // Socket receive buffer in bytes.
369 QuicFixedUint32 socket_receive_buffer_
;
374 #endif // NET_QUIC_QUIC_CONFIG_H_