mirror of
https://github.com/refraction-networking/uquic.git
synced 2025-04-04 12:47:36 +03:00
fix parsing of the Header type byte
In order to determine if a packet is a Version Negotiation Packet, it is not sufficient to just look at bit 0x1. Other packet types also have that bit set, e.g. the Retry packet (packet type 0x3). Instead, we have to look at the last 3 bits. This fix will work as long as IETF QUIC doesn't define more than 8 long header types.
This commit is contained in:
parent
df9d28cf30
commit
7c3d6abb4b
2 changed files with 22 additions and 6 deletions
|
@ -41,13 +41,14 @@ func ParseHeaderSentByServer(b *bytes.Reader, version protocol.VersionNumber) (*
|
|||
|
||||
var isPublicHeader bool
|
||||
// As a client, we know the version of the packet that the server sent, except for Version Negotiation Packets.
|
||||
// Both gQUIC and IETF QUIC Version Negotiation Packets have 0x1 set.
|
||||
if typeByte&0x1 > 0 {
|
||||
if typeByte == 0x81 { // IETF draft Version Negotiation Packet
|
||||
isPublicHeader = false
|
||||
} else if typeByte&0xcf == 0x9 { // gQUIC Version Negotiation Packet
|
||||
// IETF QUIC Version Negotiation Packets are sent with the Long Header (indicated by the 0x80 bit)
|
||||
// gQUIC always has 0x80 unset
|
||||
isPublicHeader = typeByte&0x80 == 0
|
||||
} else {
|
||||
// For all packets that are not Version Negotiation Packets, the client knows the version that this packet was sent with
|
||||
isPublicHeader = true
|
||||
} else { // not a Version Negotiation Packet
|
||||
// the client knows the version that this packet was sent with
|
||||
isPublicHeader = !version.UsesTLS()
|
||||
}
|
||||
return parsePacketHeader(b, protocol.PerspectiveServer, isPublicHeader)
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue