mirror of
				https://github.com/containers/podman.git
				synced 2025-10-26 02:35:43 +08:00 
			
		
		
		
	Merge pull request #16768 from containers/dependabot/go_modules/golang.org/x/net-0.4.0
build(deps): bump golang.org/x/net from 0.2.0 to 0.4.0
This commit is contained in:
		
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -60,7 +60,7 @@ require ( | |||||||
| 	github.com/vbauerster/mpb/v7 v7.5.3 | 	github.com/vbauerster/mpb/v7 v7.5.3 | ||||||
| 	github.com/vishvananda/netlink v1.1.1-0.20220115184804-dd687eb2f2d4 | 	github.com/vishvananda/netlink v1.1.1-0.20220115184804-dd687eb2f2d4 | ||||||
| 	go.etcd.io/bbolt v1.3.6 | 	go.etcd.io/bbolt v1.3.6 | ||||||
| 	golang.org/x/net v0.2.0 | 	golang.org/x/net v0.4.0 | ||||||
| 	golang.org/x/sync v0.1.0 | 	golang.org/x/sync v0.1.0 | ||||||
| 	golang.org/x/sys v0.3.0 | 	golang.org/x/sys v0.3.0 | ||||||
| 	golang.org/x/term v0.3.0 | 	golang.org/x/term v0.3.0 | ||||||
|  | |||||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
									
									
								
							| @ -1108,8 +1108,8 @@ golang.org/x/net v0.0.0-20210428140749-89ef3d95e781/go.mod h1:OJAsFXCWl8Ukc7SiCT | |||||||
| golang.org/x/net v0.0.0-20210825183410-e898025ed96a/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= | golang.org/x/net v0.0.0-20210825183410-e898025ed96a/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= | ||||||
| golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= | golang.org/x/net v0.0.0-20211112202133-69e39bad7dc2/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= | ||||||
| golang.org/x/net v0.0.0-20220114011407-0dd24b26b47d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= | golang.org/x/net v0.0.0-20220114011407-0dd24b26b47d/go.mod h1:9nx3DQGgdP8bBQD5qxJ1jj9UTztislL4KSBs9R2vV5Y= | ||||||
| golang.org/x/net v0.2.0 h1:sZfSu1wtKLGlWI4ZZayP0ck9Y73K1ynO6gqzTdBVdPU= | golang.org/x/net v0.4.0 h1:Q5QPcMlvfxFTAPV0+07Xz/MpK9NTXu2VDUuy0FeMfaU= | ||||||
| golang.org/x/net v0.2.0/go.mod h1:KqCZLdyyvdV855qA2rE3GC2aiw5xGR5TEjj8smXukLY= | golang.org/x/net v0.4.0/go.mod h1:MBQ8lrhLObU/6UmLb4fmbmk5OcyYmqtbGd/9yIeKjEE= | ||||||
| golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= | golang.org/x/oauth2 v0.0.0-20180821212333-d2e6202438be/go.mod h1:N/0e6XlmueqKjAGxoOufVs8QHGRruUQn6yWY3a++T0U= | ||||||
| golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= | golang.org/x/oauth2 v0.0.0-20190226205417-e64efc72b421/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= | ||||||
| golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= | golang.org/x/oauth2 v0.0.0-20190604053449-0f29369cfe45/go.mod h1:gOpvHmFTYa4IltrdGE7lF6nIHvwfUNPOp7c8zoXwtLw= | ||||||
|  | |||||||
							
								
								
									
										5
									
								
								vendor/golang.org/x/net/http2/hpack/encode.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								vendor/golang.org/x/net/http2/hpack/encode.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -116,6 +116,11 @@ func (e *Encoder) SetMaxDynamicTableSize(v uint32) { | |||||||
| 	e.dynTab.setMaxSize(v) | 	e.dynTab.setMaxSize(v) | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // MaxDynamicTableSize returns the current dynamic header table size. | ||||||
|  | func (e *Encoder) MaxDynamicTableSize() (v uint32) { | ||||||
|  | 	return e.dynTab.maxSize | ||||||
|  | } | ||||||
|  |  | ||||||
| // SetMaxDynamicTableSizeLimit changes the maximum value that can be | // SetMaxDynamicTableSizeLimit changes the maximum value that can be | ||||||
| // specified in SetMaxDynamicTableSize to v. By default, it is set to | // specified in SetMaxDynamicTableSize to v. By default, it is set to | ||||||
| // 4096, which is the same size of the default dynamic header table | // 4096, which is the same size of the default dynamic header table | ||||||
|  | |||||||
							
								
								
									
										52
									
								
								vendor/golang.org/x/net/http2/server.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										52
									
								
								vendor/golang.org/x/net/http2/server.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -98,6 +98,19 @@ type Server struct { | |||||||
| 	// the HTTP/2 spec's recommendations. | 	// the HTTP/2 spec's recommendations. | ||||||
| 	MaxConcurrentStreams uint32 | 	MaxConcurrentStreams uint32 | ||||||
|  |  | ||||||
|  | 	// MaxDecoderHeaderTableSize optionally specifies the http2 | ||||||
|  | 	// SETTINGS_HEADER_TABLE_SIZE to send in the initial settings frame. It | ||||||
|  | 	// informs the remote endpoint of the maximum size of the header compression | ||||||
|  | 	// table used to decode header blocks, in octets. If zero, the default value | ||||||
|  | 	// of 4096 is used. | ||||||
|  | 	MaxDecoderHeaderTableSize uint32 | ||||||
|  |  | ||||||
|  | 	// MaxEncoderHeaderTableSize optionally specifies an upper limit for the | ||||||
|  | 	// header compression table used for encoding request headers. Received | ||||||
|  | 	// SETTINGS_HEADER_TABLE_SIZE settings are capped at this limit. If zero, | ||||||
|  | 	// the default value of 4096 is used. | ||||||
|  | 	MaxEncoderHeaderTableSize uint32 | ||||||
|  |  | ||||||
| 	// MaxReadFrameSize optionally specifies the largest frame | 	// MaxReadFrameSize optionally specifies the largest frame | ||||||
| 	// this server is willing to read. A valid value is between | 	// this server is willing to read. A valid value is between | ||||||
| 	// 16k and 16M, inclusive. If zero or otherwise invalid, a | 	// 16k and 16M, inclusive. If zero or otherwise invalid, a | ||||||
| @ -170,6 +183,20 @@ func (s *Server) maxConcurrentStreams() uint32 { | |||||||
| 	return defaultMaxStreams | 	return defaultMaxStreams | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (s *Server) maxDecoderHeaderTableSize() uint32 { | ||||||
|  | 	if v := s.MaxDecoderHeaderTableSize; v > 0 { | ||||||
|  | 		return v | ||||||
|  | 	} | ||||||
|  | 	return initialHeaderTableSize | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (s *Server) maxEncoderHeaderTableSize() uint32 { | ||||||
|  | 	if v := s.MaxEncoderHeaderTableSize; v > 0 { | ||||||
|  | 		return v | ||||||
|  | 	} | ||||||
|  | 	return initialHeaderTableSize | ||||||
|  | } | ||||||
|  |  | ||||||
| // maxQueuedControlFrames is the maximum number of control frames like | // maxQueuedControlFrames is the maximum number of control frames like | ||||||
| // SETTINGS, PING and RST_STREAM that will be queued for writing before | // SETTINGS, PING and RST_STREAM that will be queued for writing before | ||||||
| // the connection is closed to prevent memory exhaustion attacks. | // the connection is closed to prevent memory exhaustion attacks. | ||||||
| @ -394,7 +421,6 @@ func (s *Server) ServeConn(c net.Conn, opts *ServeConnOpts) { | |||||||
| 		advMaxStreams:               s.maxConcurrentStreams(), | 		advMaxStreams:               s.maxConcurrentStreams(), | ||||||
| 		initialStreamSendWindowSize: initialWindowSize, | 		initialStreamSendWindowSize: initialWindowSize, | ||||||
| 		maxFrameSize:                initialMaxFrameSize, | 		maxFrameSize:                initialMaxFrameSize, | ||||||
| 		headerTableSize:             initialHeaderTableSize, |  | ||||||
| 		serveG:                      newGoroutineLock(), | 		serveG:                      newGoroutineLock(), | ||||||
| 		pushEnabled:                 true, | 		pushEnabled:                 true, | ||||||
| 		sawClientPreface:            opts.SawClientPreface, | 		sawClientPreface:            opts.SawClientPreface, | ||||||
| @ -424,12 +450,13 @@ func (s *Server) ServeConn(c net.Conn, opts *ServeConnOpts) { | |||||||
| 	sc.flow.add(initialWindowSize) | 	sc.flow.add(initialWindowSize) | ||||||
| 	sc.inflow.add(initialWindowSize) | 	sc.inflow.add(initialWindowSize) | ||||||
| 	sc.hpackEncoder = hpack.NewEncoder(&sc.headerWriteBuf) | 	sc.hpackEncoder = hpack.NewEncoder(&sc.headerWriteBuf) | ||||||
|  | 	sc.hpackEncoder.SetMaxDynamicTableSizeLimit(s.maxEncoderHeaderTableSize()) | ||||||
|  |  | ||||||
| 	fr := NewFramer(sc.bw, c) | 	fr := NewFramer(sc.bw, c) | ||||||
| 	if s.CountError != nil { | 	if s.CountError != nil { | ||||||
| 		fr.countError = s.CountError | 		fr.countError = s.CountError | ||||||
| 	} | 	} | ||||||
| 	fr.ReadMetaHeaders = hpack.NewDecoder(initialHeaderTableSize, nil) | 	fr.ReadMetaHeaders = hpack.NewDecoder(s.maxDecoderHeaderTableSize(), nil) | ||||||
| 	fr.MaxHeaderListSize = sc.maxHeaderListSize() | 	fr.MaxHeaderListSize = sc.maxHeaderListSize() | ||||||
| 	fr.SetMaxReadFrameSize(s.maxReadFrameSize()) | 	fr.SetMaxReadFrameSize(s.maxReadFrameSize()) | ||||||
| 	sc.framer = fr | 	sc.framer = fr | ||||||
| @ -559,9 +586,9 @@ type serverConn struct { | |||||||
| 	streams                     map[uint32]*stream | 	streams                     map[uint32]*stream | ||||||
| 	initialStreamSendWindowSize int32 | 	initialStreamSendWindowSize int32 | ||||||
| 	maxFrameSize                int32 | 	maxFrameSize                int32 | ||||||
| 	headerTableSize             uint32 |  | ||||||
| 	peerMaxHeaderListSize       uint32            // zero means unknown (default) | 	peerMaxHeaderListSize       uint32            // zero means unknown (default) | ||||||
| 	canonHeader                 map[string]string // http2-lower-case -> Go-Canonical-Case | 	canonHeader                 map[string]string // http2-lower-case -> Go-Canonical-Case | ||||||
|  | 	canonHeaderKeysSize         int               // canonHeader keys size in bytes | ||||||
| 	writingFrame                bool              // started writing a frame (on serve goroutine or separate) | 	writingFrame                bool              // started writing a frame (on serve goroutine or separate) | ||||||
| 	writingFrameAsync           bool              // started a frame on its own goroutine but haven't heard back on wroteFrameCh | 	writingFrameAsync           bool              // started a frame on its own goroutine but haven't heard back on wroteFrameCh | ||||||
| 	needsFrameFlush             bool              // last frame write wasn't a flush | 	needsFrameFlush             bool              // last frame write wasn't a flush | ||||||
| @ -740,6 +767,13 @@ func (sc *serverConn) condlogf(err error, format string, args ...interface{}) { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  |  | ||||||
|  | // maxCachedCanonicalHeadersKeysSize is an arbitrarily-chosen limit on the size | ||||||
|  | // of the entries in the canonHeader cache. | ||||||
|  | // This should be larger than the size of unique, uncommon header keys likely to | ||||||
|  | // be sent by the peer, while not so high as to permit unreasonable memory usage | ||||||
|  | // if the peer sends an unbounded number of unique header keys. | ||||||
|  | const maxCachedCanonicalHeadersKeysSize = 2048 | ||||||
|  |  | ||||||
| func (sc *serverConn) canonicalHeader(v string) string { | func (sc *serverConn) canonicalHeader(v string) string { | ||||||
| 	sc.serveG.check() | 	sc.serveG.check() | ||||||
| 	buildCommonHeaderMapsOnce() | 	buildCommonHeaderMapsOnce() | ||||||
| @ -755,14 +789,10 @@ func (sc *serverConn) canonicalHeader(v string) string { | |||||||
| 		sc.canonHeader = make(map[string]string) | 		sc.canonHeader = make(map[string]string) | ||||||
| 	} | 	} | ||||||
| 	cv = http.CanonicalHeaderKey(v) | 	cv = http.CanonicalHeaderKey(v) | ||||||
| 	// maxCachedCanonicalHeaders is an arbitrarily-chosen limit on the number of | 	size := 100 + len(v)*2 // 100 bytes of map overhead + key + value | ||||||
| 	// entries in the canonHeader cache. This should be larger than the number | 	if sc.canonHeaderKeysSize+size <= maxCachedCanonicalHeadersKeysSize { | ||||||
| 	// of unique, uncommon header keys likely to be sent by the peer, while not |  | ||||||
| 	// so high as to permit unreasonable memory usage if the peer sends an unbounded |  | ||||||
| 	// number of unique header keys. |  | ||||||
| 	const maxCachedCanonicalHeaders = 32 |  | ||||||
| 	if len(sc.canonHeader) < maxCachedCanonicalHeaders { |  | ||||||
| 		sc.canonHeader[v] = cv | 		sc.canonHeader[v] = cv | ||||||
|  | 		sc.canonHeaderKeysSize += size | ||||||
| 	} | 	} | ||||||
| 	return cv | 	return cv | ||||||
| } | } | ||||||
| @ -864,6 +894,7 @@ func (sc *serverConn) serve() { | |||||||
| 			{SettingMaxFrameSize, sc.srv.maxReadFrameSize()}, | 			{SettingMaxFrameSize, sc.srv.maxReadFrameSize()}, | ||||||
| 			{SettingMaxConcurrentStreams, sc.advMaxStreams}, | 			{SettingMaxConcurrentStreams, sc.advMaxStreams}, | ||||||
| 			{SettingMaxHeaderListSize, sc.maxHeaderListSize()}, | 			{SettingMaxHeaderListSize, sc.maxHeaderListSize()}, | ||||||
|  | 			{SettingHeaderTableSize, sc.srv.maxDecoderHeaderTableSize()}, | ||||||
| 			{SettingInitialWindowSize, uint32(sc.srv.initialStreamRecvWindowSize())}, | 			{SettingInitialWindowSize, uint32(sc.srv.initialStreamRecvWindowSize())}, | ||||||
| 		}, | 		}, | ||||||
| 	}) | 	}) | ||||||
| @ -1661,7 +1692,6 @@ func (sc *serverConn) processSetting(s Setting) error { | |||||||
| 	} | 	} | ||||||
| 	switch s.ID { | 	switch s.ID { | ||||||
| 	case SettingHeaderTableSize: | 	case SettingHeaderTableSize: | ||||||
| 		sc.headerTableSize = s.Val |  | ||||||
| 		sc.hpackEncoder.SetMaxDynamicTableSize(s.Val) | 		sc.hpackEncoder.SetMaxDynamicTableSize(s.Val) | ||||||
| 	case SettingEnablePush: | 	case SettingEnablePush: | ||||||
| 		sc.pushEnabled = s.Val != 0 | 		sc.pushEnabled = s.Val != 0 | ||||||
|  | |||||||
							
								
								
									
										70
									
								
								vendor/golang.org/x/net/http2/transport.go
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										70
									
								
								vendor/golang.org/x/net/http2/transport.go
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -118,6 +118,28 @@ type Transport struct { | |||||||
| 	// to mean no limit. | 	// to mean no limit. | ||||||
| 	MaxHeaderListSize uint32 | 	MaxHeaderListSize uint32 | ||||||
|  |  | ||||||
|  | 	// MaxReadFrameSize is the http2 SETTINGS_MAX_FRAME_SIZE to send in the | ||||||
|  | 	// initial settings frame. It is the size in bytes of the largest frame | ||||||
|  | 	// payload that the sender is willing to receive. If 0, no setting is | ||||||
|  | 	// sent, and the value is provided by the peer, which should be 16384 | ||||||
|  | 	// according to the spec: | ||||||
|  | 	// https://datatracker.ietf.org/doc/html/rfc7540#section-6.5.2. | ||||||
|  | 	// Values are bounded in the range 16k to 16M. | ||||||
|  | 	MaxReadFrameSize uint32 | ||||||
|  |  | ||||||
|  | 	// MaxDecoderHeaderTableSize optionally specifies the http2 | ||||||
|  | 	// SETTINGS_HEADER_TABLE_SIZE to send in the initial settings frame. It | ||||||
|  | 	// informs the remote endpoint of the maximum size of the header compression | ||||||
|  | 	// table used to decode header blocks, in octets. If zero, the default value | ||||||
|  | 	// of 4096 is used. | ||||||
|  | 	MaxDecoderHeaderTableSize uint32 | ||||||
|  |  | ||||||
|  | 	// MaxEncoderHeaderTableSize optionally specifies an upper limit for the | ||||||
|  | 	// header compression table used for encoding request headers. Received | ||||||
|  | 	// SETTINGS_HEADER_TABLE_SIZE settings are capped at this limit. If zero, | ||||||
|  | 	// the default value of 4096 is used. | ||||||
|  | 	MaxEncoderHeaderTableSize uint32 | ||||||
|  |  | ||||||
| 	// StrictMaxConcurrentStreams controls whether the server's | 	// StrictMaxConcurrentStreams controls whether the server's | ||||||
| 	// SETTINGS_MAX_CONCURRENT_STREAMS should be respected | 	// SETTINGS_MAX_CONCURRENT_STREAMS should be respected | ||||||
| 	// globally. If false, new TCP connections are created to the | 	// globally. If false, new TCP connections are created to the | ||||||
| @ -171,6 +193,19 @@ func (t *Transport) maxHeaderListSize() uint32 { | |||||||
| 	return t.MaxHeaderListSize | 	return t.MaxHeaderListSize | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (t *Transport) maxFrameReadSize() uint32 { | ||||||
|  | 	if t.MaxReadFrameSize == 0 { | ||||||
|  | 		return 0 // use the default provided by the peer | ||||||
|  | 	} | ||||||
|  | 	if t.MaxReadFrameSize < minMaxFrameSize { | ||||||
|  | 		return minMaxFrameSize | ||||||
|  | 	} | ||||||
|  | 	if t.MaxReadFrameSize > maxFrameSize { | ||||||
|  | 		return maxFrameSize | ||||||
|  | 	} | ||||||
|  | 	return t.MaxReadFrameSize | ||||||
|  | } | ||||||
|  |  | ||||||
| func (t *Transport) disableCompression() bool { | func (t *Transport) disableCompression() bool { | ||||||
| 	return t.DisableCompression || (t.t1 != nil && t.t1.DisableCompression) | 	return t.DisableCompression || (t.t1 != nil && t.t1.DisableCompression) | ||||||
| } | } | ||||||
| @ -296,6 +331,7 @@ type ClientConn struct { | |||||||
| 	maxFrameSize           uint32 | 	maxFrameSize           uint32 | ||||||
| 	maxConcurrentStreams   uint32 | 	maxConcurrentStreams   uint32 | ||||||
| 	peerMaxHeaderListSize  uint64 | 	peerMaxHeaderListSize  uint64 | ||||||
|  | 	peerMaxHeaderTableSize uint32 | ||||||
| 	initialWindowSize      uint32 | 	initialWindowSize      uint32 | ||||||
|  |  | ||||||
| 	// reqHeaderMu is a 1-element semaphore channel controlling access to sending new requests. | 	// reqHeaderMu is a 1-element semaphore channel controlling access to sending new requests. | ||||||
| @ -681,6 +717,20 @@ func (t *Transport) expectContinueTimeout() time.Duration { | |||||||
| 	return t.t1.ExpectContinueTimeout | 	return t.t1.ExpectContinueTimeout | ||||||
| } | } | ||||||
|  |  | ||||||
|  | func (t *Transport) maxDecoderHeaderTableSize() uint32 { | ||||||
|  | 	if v := t.MaxDecoderHeaderTableSize; v > 0 { | ||||||
|  | 		return v | ||||||
|  | 	} | ||||||
|  | 	return initialHeaderTableSize | ||||||
|  | } | ||||||
|  |  | ||||||
|  | func (t *Transport) maxEncoderHeaderTableSize() uint32 { | ||||||
|  | 	if v := t.MaxEncoderHeaderTableSize; v > 0 { | ||||||
|  | 		return v | ||||||
|  | 	} | ||||||
|  | 	return initialHeaderTableSize | ||||||
|  | } | ||||||
|  |  | ||||||
| func (t *Transport) NewClientConn(c net.Conn) (*ClientConn, error) { | func (t *Transport) NewClientConn(c net.Conn) (*ClientConn, error) { | ||||||
| 	return t.newClientConn(c, t.disableKeepAlives()) | 	return t.newClientConn(c, t.disableKeepAlives()) | ||||||
| } | } | ||||||
| @ -721,15 +771,19 @@ func (t *Transport) newClientConn(c net.Conn, singleUse bool) (*ClientConn, erro | |||||||
| 	}) | 	}) | ||||||
| 	cc.br = bufio.NewReader(c) | 	cc.br = bufio.NewReader(c) | ||||||
| 	cc.fr = NewFramer(cc.bw, cc.br) | 	cc.fr = NewFramer(cc.bw, cc.br) | ||||||
|  | 	if t.maxFrameReadSize() != 0 { | ||||||
|  | 		cc.fr.SetMaxReadFrameSize(t.maxFrameReadSize()) | ||||||
|  | 	} | ||||||
| 	if t.CountError != nil { | 	if t.CountError != nil { | ||||||
| 		cc.fr.countError = t.CountError | 		cc.fr.countError = t.CountError | ||||||
| 	} | 	} | ||||||
| 	cc.fr.ReadMetaHeaders = hpack.NewDecoder(initialHeaderTableSize, nil) | 	maxHeaderTableSize := t.maxDecoderHeaderTableSize() | ||||||
|  | 	cc.fr.ReadMetaHeaders = hpack.NewDecoder(maxHeaderTableSize, nil) | ||||||
| 	cc.fr.MaxHeaderListSize = t.maxHeaderListSize() | 	cc.fr.MaxHeaderListSize = t.maxHeaderListSize() | ||||||
|  |  | ||||||
| 	// TODO: SetMaxDynamicTableSize, SetMaxDynamicTableSizeLimit on |  | ||||||
| 	// henc in response to SETTINGS frames? |  | ||||||
| 	cc.henc = hpack.NewEncoder(&cc.hbuf) | 	cc.henc = hpack.NewEncoder(&cc.hbuf) | ||||||
|  | 	cc.henc.SetMaxDynamicTableSizeLimit(t.maxEncoderHeaderTableSize()) | ||||||
|  | 	cc.peerMaxHeaderTableSize = initialHeaderTableSize | ||||||
|  |  | ||||||
| 	if t.AllowHTTP { | 	if t.AllowHTTP { | ||||||
| 		cc.nextStreamID = 3 | 		cc.nextStreamID = 3 | ||||||
| @ -744,9 +798,15 @@ func (t *Transport) newClientConn(c net.Conn, singleUse bool) (*ClientConn, erro | |||||||
| 		{ID: SettingEnablePush, Val: 0}, | 		{ID: SettingEnablePush, Val: 0}, | ||||||
| 		{ID: SettingInitialWindowSize, Val: transportDefaultStreamFlow}, | 		{ID: SettingInitialWindowSize, Val: transportDefaultStreamFlow}, | ||||||
| 	} | 	} | ||||||
|  | 	if max := t.maxFrameReadSize(); max != 0 { | ||||||
|  | 		initialSettings = append(initialSettings, Setting{ID: SettingMaxFrameSize, Val: max}) | ||||||
|  | 	} | ||||||
| 	if max := t.maxHeaderListSize(); max != 0 { | 	if max := t.maxHeaderListSize(); max != 0 { | ||||||
| 		initialSettings = append(initialSettings, Setting{ID: SettingMaxHeaderListSize, Val: max}) | 		initialSettings = append(initialSettings, Setting{ID: SettingMaxHeaderListSize, Val: max}) | ||||||
| 	} | 	} | ||||||
|  | 	if maxHeaderTableSize != initialHeaderTableSize { | ||||||
|  | 		initialSettings = append(initialSettings, Setting{ID: SettingHeaderTableSize, Val: maxHeaderTableSize}) | ||||||
|  | 	} | ||||||
|  |  | ||||||
| 	cc.bw.Write(clientPreface) | 	cc.bw.Write(clientPreface) | ||||||
| 	cc.fr.WriteSettings(initialSettings...) | 	cc.fr.WriteSettings(initialSettings...) | ||||||
| @ -2773,8 +2833,10 @@ func (rl *clientConnReadLoop) processSettingsNoWrite(f *SettingsFrame) error { | |||||||
| 			cc.cond.Broadcast() | 			cc.cond.Broadcast() | ||||||
|  |  | ||||||
| 			cc.initialWindowSize = s.Val | 			cc.initialWindowSize = s.Val | ||||||
|  | 		case SettingHeaderTableSize: | ||||||
|  | 			cc.henc.SetMaxDynamicTableSize(s.Val) | ||||||
|  | 			cc.peerMaxHeaderTableSize = s.Val | ||||||
| 		default: | 		default: | ||||||
| 			// TODO(bradfitz): handle more settings? SETTINGS_HEADER_TABLE_SIZE probably. |  | ||||||
| 			cc.vlogf("Unhandled Setting: %v", s) | 			cc.vlogf("Unhandled Setting: %v", s) | ||||||
| 		} | 		} | ||||||
| 		return nil | 		return nil | ||||||
|  | |||||||
							
								
								
									
										2
									
								
								vendor/modules.txt
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								vendor/modules.txt
									
									
									
									
										vendored
									
									
								
							| @ -793,7 +793,7 @@ golang.org/x/crypto/ssh/knownhosts | |||||||
| # golang.org/x/mod v0.6.0 | # golang.org/x/mod v0.6.0 | ||||||
| ## explicit; go 1.17 | ## explicit; go 1.17 | ||||||
| golang.org/x/mod/semver | golang.org/x/mod/semver | ||||||
| # golang.org/x/net v0.2.0 | # golang.org/x/net v0.4.0 | ||||||
| ## explicit; go 1.17 | ## explicit; go 1.17 | ||||||
| golang.org/x/net/context | golang.org/x/net/context | ||||||
| golang.org/x/net/html | golang.org/x/net/html | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user
	 OpenShift Merge Robot
					OpenShift Merge Robot