mirror of
https://github.com/DNSCrypt/dnscrypt-proxy.git
synced 2025-04-04 05:37:38 +03:00
Update quic-go to fix two regressions
This commit is contained in:
parent
1792c06bc7
commit
0a98be94a7
7 changed files with 38 additions and 6 deletions
2
go.mod
2
go.mod
|
@ -20,7 +20,7 @@ require (
|
||||||
github.com/kardianos/service v1.2.2
|
github.com/kardianos/service v1.2.2
|
||||||
github.com/miekg/dns v1.1.55
|
github.com/miekg/dns v1.1.55
|
||||||
github.com/powerman/check v1.7.0
|
github.com/powerman/check v1.7.0
|
||||||
github.com/quic-go/quic-go v0.37.0
|
github.com/quic-go/quic-go v0.37.1
|
||||||
golang.org/x/crypto v0.11.0
|
golang.org/x/crypto v0.11.0
|
||||||
golang.org/x/net v0.12.0
|
golang.org/x/net v0.12.0
|
||||||
golang.org/x/sys v0.10.0
|
golang.org/x/sys v0.10.0
|
||||||
|
|
4
go.sum
4
go.sum
|
@ -72,8 +72,8 @@ github.com/quic-go/qpack v0.4.0 h1:Cr9BXA1sQS2SmDUWjSofMPNKmvF6IiIfDRmgU0w1ZCo=
|
||||||
github.com/quic-go/qpack v0.4.0/go.mod h1:UZVnYIfi5GRk+zI9UMaCPsmZ2xKJP7XBUvVyT1Knj9A=
|
github.com/quic-go/qpack v0.4.0/go.mod h1:UZVnYIfi5GRk+zI9UMaCPsmZ2xKJP7XBUvVyT1Knj9A=
|
||||||
github.com/quic-go/qtls-go1-20 v0.3.0 h1:NrCXmDl8BddZwO67vlvEpBTwT89bJfKYygxv4HQvuDk=
|
github.com/quic-go/qtls-go1-20 v0.3.0 h1:NrCXmDl8BddZwO67vlvEpBTwT89bJfKYygxv4HQvuDk=
|
||||||
github.com/quic-go/qtls-go1-20 v0.3.0/go.mod h1:X9Nh97ZL80Z+bX/gUXMbipO6OxdiDi58b/fMC9mAL+k=
|
github.com/quic-go/qtls-go1-20 v0.3.0/go.mod h1:X9Nh97ZL80Z+bX/gUXMbipO6OxdiDi58b/fMC9mAL+k=
|
||||||
github.com/quic-go/quic-go v0.37.0 h1:wf/Ym2yeWi98oQn4ahiBSqdnaXVxNQGj2oBQFgiVChc=
|
github.com/quic-go/quic-go v0.37.1 h1:M+mcsFq9KoxVjCetIwH65TvusW1UdRBc6zmxI6pkeD0=
|
||||||
github.com/quic-go/quic-go v0.37.0/go.mod h1:XtCUOCALTTWbPyd0IxFfHf6h0sEMubRFvEYHl3QxKw8=
|
github.com/quic-go/quic-go v0.37.1/go.mod h1:XtCUOCALTTWbPyd0IxFfHf6h0sEMubRFvEYHl3QxKw8=
|
||||||
github.com/smartystreets/assertions v1.2.0 h1:42S6lae5dvLc7BrLu/0ugRtcFVjoJNMC/N3yZFZkDFs=
|
github.com/smartystreets/assertions v1.2.0 h1:42S6lae5dvLc7BrLu/0ugRtcFVjoJNMC/N3yZFZkDFs=
|
||||||
github.com/smartystreets/assertions v1.2.0/go.mod h1:tcbTF8ujkAEcZ8TElKY+i30BzYlVhC/LOxJk7iOWnoo=
|
github.com/smartystreets/assertions v1.2.0/go.mod h1:tcbTF8ujkAEcZ8TElKY+i30BzYlVhC/LOxJk7iOWnoo=
|
||||||
github.com/smartystreets/goconvey v1.7.2 h1:9RBaZCeXEQ3UselpuwUQHltGVXvdwm6cv1hgR6gDIPg=
|
github.com/smartystreets/goconvey v1.7.2 h1:9RBaZCeXEQ3UselpuwUQHltGVXvdwm6cv1hgR6gDIPg=
|
||||||
|
|
2
vendor/github.com/quic-go/quic-go/connection.go
generated
vendored
2
vendor/github.com/quic-go/quic-go/connection.go
generated
vendored
|
@ -315,6 +315,8 @@ var newConnection = func(
|
||||||
}
|
}
|
||||||
cs := handshake.NewCryptoSetupServer(
|
cs := handshake.NewCryptoSetupServer(
|
||||||
clientDestConnID,
|
clientDestConnID,
|
||||||
|
conn.LocalAddr(),
|
||||||
|
conn.RemoteAddr(),
|
||||||
params,
|
params,
|
||||||
tlsConf,
|
tlsConf,
|
||||||
conf.Allow0RTT,
|
conf.Allow0RTT,
|
||||||
|
|
4
vendor/github.com/quic-go/quic-go/http3/client.go
generated
vendored
4
vendor/github.com/quic-go/quic-go/http3/client.go
generated
vendored
|
@ -429,8 +429,8 @@ func (c *client) doRequest(req *http.Request, conn quic.EarlyConnection, str qui
|
||||||
// Check that the server doesn't send more data in DATA frames than indicated by the Content-Length header (if set).
|
// Check that the server doesn't send more data in DATA frames than indicated by the Content-Length header (if set).
|
||||||
// See section 4.1.2 of RFC 9114.
|
// See section 4.1.2 of RFC 9114.
|
||||||
var httpStr Stream
|
var httpStr Stream
|
||||||
if _, ok := req.Header["Content-Length"]; ok && req.ContentLength >= 0 {
|
if _, ok := res.Header["Content-Length"]; ok && res.ContentLength >= 0 {
|
||||||
httpStr = newLengthLimitedStream(hstr, req.ContentLength)
|
httpStr = newLengthLimitedStream(hstr, res.ContentLength)
|
||||||
} else {
|
} else {
|
||||||
httpStr = hstr
|
httpStr = hstr
|
||||||
}
|
}
|
||||||
|
|
21
vendor/github.com/quic-go/quic-go/internal/handshake/conn.go
generated
vendored
Normal file
21
vendor/github.com/quic-go/quic-go/internal/handshake/conn.go
generated
vendored
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
package handshake
|
||||||
|
|
||||||
|
import (
|
||||||
|
"net"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
type conn struct {
|
||||||
|
localAddr, remoteAddr net.Addr
|
||||||
|
}
|
||||||
|
|
||||||
|
var _ net.Conn = &conn{}
|
||||||
|
|
||||||
|
func (c *conn) Read([]byte) (int, error) { return 0, nil }
|
||||||
|
func (c *conn) Write([]byte) (int, error) { return 0, nil }
|
||||||
|
func (c *conn) Close() error { return nil }
|
||||||
|
func (c *conn) RemoteAddr() net.Addr { return c.remoteAddr }
|
||||||
|
func (c *conn) LocalAddr() net.Addr { return c.localAddr }
|
||||||
|
func (c *conn) SetReadDeadline(time.Time) error { return nil }
|
||||||
|
func (c *conn) SetWriteDeadline(time.Time) error { return nil }
|
||||||
|
func (c *conn) SetDeadline(time.Time) error { return nil }
|
9
vendor/github.com/quic-go/quic-go/internal/handshake/crypto_setup.go
generated
vendored
9
vendor/github.com/quic-go/quic-go/internal/handshake/crypto_setup.go
generated
vendored
|
@ -6,6 +6,7 @@ import (
|
||||||
"crypto/tls"
|
"crypto/tls"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"net"
|
||||||
"sync"
|
"sync"
|
||||||
"sync/atomic"
|
"sync/atomic"
|
||||||
"time"
|
"time"
|
||||||
|
@ -104,6 +105,7 @@ func NewCryptoSetupClient(
|
||||||
// NewCryptoSetupServer creates a new crypto setup for the server
|
// NewCryptoSetupServer creates a new crypto setup for the server
|
||||||
func NewCryptoSetupServer(
|
func NewCryptoSetupServer(
|
||||||
connID protocol.ConnectionID,
|
connID protocol.ConnectionID,
|
||||||
|
localAddr, remoteAddr net.Addr,
|
||||||
tp *wire.TransportParameters,
|
tp *wire.TransportParameters,
|
||||||
tlsConf *tls.Config,
|
tlsConf *tls.Config,
|
||||||
allow0RTT bool,
|
allow0RTT bool,
|
||||||
|
@ -125,6 +127,13 @@ func NewCryptoSetupServer(
|
||||||
|
|
||||||
quicConf := &qtls.QUICConfig{TLSConfig: tlsConf}
|
quicConf := &qtls.QUICConfig{TLSConfig: tlsConf}
|
||||||
qtls.SetupConfigForServer(quicConf, cs.allow0RTT, cs.getDataForSessionTicket, cs.accept0RTT)
|
qtls.SetupConfigForServer(quicConf, cs.allow0RTT, cs.getDataForSessionTicket, cs.accept0RTT)
|
||||||
|
if quicConf.TLSConfig.GetConfigForClient != nil {
|
||||||
|
gcfc := quicConf.TLSConfig.GetConfigForClient
|
||||||
|
quicConf.TLSConfig.GetConfigForClient = func(info *tls.ClientHelloInfo) (*tls.Config, error) {
|
||||||
|
info.Conn = &conn{localAddr: localAddr, remoteAddr: remoteAddr}
|
||||||
|
return gcfc(info)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
cs.tlsConf = quicConf.TLSConfig
|
cs.tlsConf = quicConf.TLSConfig
|
||||||
cs.conn = qtls.QUICServer(quicConf)
|
cs.conn = qtls.QUICServer(quicConf)
|
||||||
|
|
2
vendor/modules.txt
vendored
2
vendor/modules.txt
vendored
|
@ -109,7 +109,7 @@ github.com/quic-go/qpack
|
||||||
# github.com/quic-go/qtls-go1-20 v0.3.0
|
# github.com/quic-go/qtls-go1-20 v0.3.0
|
||||||
## explicit; go 1.20
|
## explicit; go 1.20
|
||||||
github.com/quic-go/qtls-go1-20
|
github.com/quic-go/qtls-go1-20
|
||||||
# github.com/quic-go/quic-go v0.37.0
|
# github.com/quic-go/quic-go v0.37.1
|
||||||
## explicit; go 1.20
|
## explicit; go 1.20
|
||||||
github.com/quic-go/quic-go
|
github.com/quic-go/quic-go
|
||||||
github.com/quic-go/quic-go/http3
|
github.com/quic-go/quic-go/http3
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue