mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 20:57:36 +03:00
add a config option to disable sending of Version Negotiation packets
This commit is contained in:
parent
e9d12b7f83
commit
3a359027b5
5 changed files with 47 additions and 18 deletions
35
config.go
35
config.go
|
@ -101,22 +101,23 @@ func populateConfig(config *Config) *Config {
|
||||||
}
|
}
|
||||||
|
|
||||||
return &Config{
|
return &Config{
|
||||||
Versions: versions,
|
Versions: versions,
|
||||||
HandshakeIdleTimeout: handshakeIdleTimeout,
|
HandshakeIdleTimeout: handshakeIdleTimeout,
|
||||||
MaxIdleTimeout: idleTimeout,
|
MaxIdleTimeout: idleTimeout,
|
||||||
AcceptToken: config.AcceptToken,
|
AcceptToken: config.AcceptToken,
|
||||||
KeepAlive: config.KeepAlive,
|
KeepAlive: config.KeepAlive,
|
||||||
InitialStreamReceiveWindow: initialStreamReceiveWindow,
|
InitialStreamReceiveWindow: initialStreamReceiveWindow,
|
||||||
MaxStreamReceiveWindow: maxStreamReceiveWindow,
|
MaxStreamReceiveWindow: maxStreamReceiveWindow,
|
||||||
InitialConnectionReceiveWindow: initialConnectionReceiveWindow,
|
InitialConnectionReceiveWindow: initialConnectionReceiveWindow,
|
||||||
MaxConnectionReceiveWindow: maxConnectionReceiveWindow,
|
MaxConnectionReceiveWindow: maxConnectionReceiveWindow,
|
||||||
MaxIncomingStreams: maxIncomingStreams,
|
MaxIncomingStreams: maxIncomingStreams,
|
||||||
MaxIncomingUniStreams: maxIncomingUniStreams,
|
MaxIncomingUniStreams: maxIncomingUniStreams,
|
||||||
ConnectionIDLength: config.ConnectionIDLength,
|
ConnectionIDLength: config.ConnectionIDLength,
|
||||||
StatelessResetKey: config.StatelessResetKey,
|
StatelessResetKey: config.StatelessResetKey,
|
||||||
TokenStore: config.TokenStore,
|
TokenStore: config.TokenStore,
|
||||||
EnableDatagrams: config.EnableDatagrams,
|
EnableDatagrams: config.EnableDatagrams,
|
||||||
DisablePathMTUDiscovery: config.DisablePathMTUDiscovery,
|
DisablePathMTUDiscovery: config.DisablePathMTUDiscovery,
|
||||||
Tracer: config.Tracer,
|
DisableVersionNegotiationPackets: config.DisableVersionNegotiationPackets,
|
||||||
|
Tracer: config.Tracer,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -75,6 +75,8 @@ var _ = Describe("Config", func() {
|
||||||
f.Set(reflect.ValueOf(true))
|
f.Set(reflect.ValueOf(true))
|
||||||
case "EnableDatagrams":
|
case "EnableDatagrams":
|
||||||
f.Set(reflect.ValueOf(true))
|
f.Set(reflect.ValueOf(true))
|
||||||
|
case "DisableVersionNegotiationPackets":
|
||||||
|
f.Set(reflect.ValueOf(true))
|
||||||
case "DisablePathMTUDiscovery":
|
case "DisablePathMTUDiscovery":
|
||||||
f.Set(reflect.ValueOf(true))
|
f.Set(reflect.ValueOf(true))
|
||||||
case "Tracer":
|
case "Tracer":
|
||||||
|
@ -152,6 +154,7 @@ var _ = Describe("Config", func() {
|
||||||
Expect(c.MaxConnectionReceiveWindow).To(BeEquivalentTo(protocol.DefaultMaxReceiveConnectionFlowControlWindow))
|
Expect(c.MaxConnectionReceiveWindow).To(BeEquivalentTo(protocol.DefaultMaxReceiveConnectionFlowControlWindow))
|
||||||
Expect(c.MaxIncomingStreams).To(BeEquivalentTo(protocol.DefaultMaxIncomingStreams))
|
Expect(c.MaxIncomingStreams).To(BeEquivalentTo(protocol.DefaultMaxIncomingStreams))
|
||||||
Expect(c.MaxIncomingUniStreams).To(BeEquivalentTo(protocol.DefaultMaxIncomingUniStreams))
|
Expect(c.MaxIncomingUniStreams).To(BeEquivalentTo(protocol.DefaultMaxIncomingUniStreams))
|
||||||
|
Expect(c.DisableVersionNegotiationPackets).To(BeFalse())
|
||||||
Expect(c.DisablePathMTUDiscovery).To(BeFalse())
|
Expect(c.DisablePathMTUDiscovery).To(BeFalse())
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|
|
@ -298,6 +298,10 @@ type Config struct {
|
||||||
// DisablePathMTUDiscovery disables Path MTU Discovery (RFC 8899).
|
// DisablePathMTUDiscovery disables Path MTU Discovery (RFC 8899).
|
||||||
// Packets will then be at most 1252 (IPv4) / 1232 (IPv6) bytes in size.
|
// Packets will then be at most 1252 (IPv4) / 1232 (IPv6) bytes in size.
|
||||||
DisablePathMTUDiscovery bool
|
DisablePathMTUDiscovery bool
|
||||||
|
// DisableVersionNegotiationPackets disables the sending of Version Negotiation packets.
|
||||||
|
// This can be useful if version information is exchanged out-of-band.
|
||||||
|
// It has no effect for a client.
|
||||||
|
DisableVersionNegotiationPackets bool
|
||||||
// See https://datatracker.ietf.org/doc/draft-ietf-quic-datagram/.
|
// See https://datatracker.ietf.org/doc/draft-ietf-quic-datagram/.
|
||||||
// Datagrams will only be available when both peers enable datagram support.
|
// Datagrams will only be available when both peers enable datagram support.
|
||||||
EnableDatagrams bool
|
EnableDatagrams bool
|
||||||
|
|
|
@ -366,7 +366,9 @@ func (s *baseServer) handlePacketImpl(p *receivedPacket) bool /* is the buffer s
|
||||||
}
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
go s.sendVersionNegotiationPacket(p, hdr)
|
if !s.config.DisableVersionNegotiationPackets {
|
||||||
|
go s.sendVersionNegotiationPacket(p, hdr)
|
||||||
|
}
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
if hdr.IsLongHeader && hdr.Type != protocol.PacketTypeInitial {
|
if hdr.IsLongHeader && hdr.Type != protocol.PacketTypeInitial {
|
||||||
|
|
|
@ -406,6 +406,25 @@ var _ = Describe("Server", func() {
|
||||||
Eventually(done).Should(BeClosed())
|
Eventually(done).Should(BeClosed())
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("doesn't send a Version Negotiation packets if sending them is disabled", func() {
|
||||||
|
serv.config.DisableVersionNegotiationPackets = true
|
||||||
|
srcConnID := protocol.ConnectionID{1, 2, 3, 4, 5}
|
||||||
|
destConnID := protocol.ConnectionID{1, 2, 3, 4, 5, 6}
|
||||||
|
packet := getPacket(&wire.Header{
|
||||||
|
IsLongHeader: true,
|
||||||
|
Type: protocol.PacketTypeHandshake,
|
||||||
|
SrcConnectionID: srcConnID,
|
||||||
|
DestConnectionID: destConnID,
|
||||||
|
Version: 0x42,
|
||||||
|
}, make([]byte, protocol.MinUnknownVersionPacketSize))
|
||||||
|
raddr := &net.UDPAddr{IP: net.IPv4(127, 0, 0, 1), Port: 1337}
|
||||||
|
packet.remoteAddr = raddr
|
||||||
|
done := make(chan struct{})
|
||||||
|
conn.EXPECT().WriteTo(gomock.Any(), raddr).Do(func() { close(done) }).Times(0)
|
||||||
|
serv.handlePacket(packet)
|
||||||
|
Consistently(done, 50*time.Millisecond).ShouldNot(BeClosed())
|
||||||
|
})
|
||||||
|
|
||||||
It("ignores Version Negotiation packets", func() {
|
It("ignores Version Negotiation packets", func() {
|
||||||
data, err := wire.ComposeVersionNegotiation(
|
data, err := wire.ComposeVersionNegotiation(
|
||||||
protocol.ConnectionID{1, 2, 3, 4},
|
protocol.ConnectionID{1, 2, 3, 4},
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue