forked from quic-go/quic-go
remove the wire.ShortHeader in favor of more return values (#3535)
This commit is contained in:
@@ -9,28 +9,20 @@ import (
|
||||
"github.com/lucas-clemente/quic-go/internal/utils"
|
||||
)
|
||||
|
||||
type ShortHeader struct {
|
||||
DestConnectionID protocol.ConnectionID
|
||||
PacketNumber protocol.PacketNumber
|
||||
PacketNumberLen protocol.PacketNumberLen
|
||||
KeyPhase protocol.KeyPhaseBit
|
||||
}
|
||||
|
||||
func ParseShortHeader(data []byte, connIDLen int) (*ShortHeader, error) {
|
||||
func ParseShortHeader(data []byte, connIDLen int) (length int, _ protocol.PacketNumber, _ protocol.PacketNumberLen, _ protocol.KeyPhaseBit, _ error) {
|
||||
if len(data) == 0 {
|
||||
return nil, io.EOF
|
||||
return 0, 0, 0, 0, io.EOF
|
||||
}
|
||||
if data[0]&0x80 > 0 {
|
||||
return nil, errors.New("not a short header packet")
|
||||
return 0, 0, 0, 0, errors.New("not a short header packet")
|
||||
}
|
||||
if data[0]&0x40 == 0 {
|
||||
return nil, errors.New("not a QUIC packet")
|
||||
return 0, 0, 0, 0, errors.New("not a QUIC packet")
|
||||
}
|
||||
pnLen := protocol.PacketNumberLen(data[0]&0b11) + 1
|
||||
if len(data) < 1+int(pnLen)+connIDLen {
|
||||
return nil, io.EOF
|
||||
return 0, 0, 0, 0, io.EOF
|
||||
}
|
||||
destConnID := protocol.ParseConnectionID(data[1 : 1+connIDLen])
|
||||
|
||||
pos := 1 + connIDLen
|
||||
var pn protocol.PacketNumber
|
||||
@@ -44,7 +36,7 @@ func ParseShortHeader(data []byte, connIDLen int) (*ShortHeader, error) {
|
||||
case protocol.PacketNumberLen4:
|
||||
pn = protocol.PacketNumber(utils.BigEndian.Uint32(data[pos : pos+4]))
|
||||
default:
|
||||
return nil, fmt.Errorf("invalid packet number length: %d", pnLen)
|
||||
return 0, 0, 0, 0, fmt.Errorf("invalid packet number length: %d", pnLen)
|
||||
}
|
||||
kp := protocol.KeyPhaseZero
|
||||
if data[0]&0b100 > 0 {
|
||||
@@ -55,19 +47,9 @@ func ParseShortHeader(data []byte, connIDLen int) (*ShortHeader, error) {
|
||||
if data[0]&0x18 != 0 {
|
||||
err = ErrInvalidReservedBits
|
||||
}
|
||||
return &ShortHeader{
|
||||
DestConnectionID: destConnID,
|
||||
PacketNumber: pn,
|
||||
PacketNumberLen: pnLen,
|
||||
KeyPhase: kp,
|
||||
}, err
|
||||
return 1 + connIDLen + int(pnLen), pn, pnLen, kp, err
|
||||
}
|
||||
|
||||
func (h *ShortHeader) Len() protocol.ByteCount {
|
||||
return 1 + protocol.ByteCount(h.DestConnectionID.Len()) + protocol.ByteCount(h.PacketNumberLen)
|
||||
}
|
||||
|
||||
// Log logs the Header
|
||||
func (h *ShortHeader) Log(logger utils.Logger) {
|
||||
logger.Debugf("\tShort Header{DestConnectionID: %s, PacketNumber: %d, PacketNumberLen: %d, KeyPhase: %s}", h.DestConnectionID, h.PacketNumber, h.PacketNumberLen, h.KeyPhase)
|
||||
func LogShortHeader(logger utils.Logger, dest protocol.ConnectionID, pn protocol.PacketNumber, pnLen protocol.PacketNumberLen, kp protocol.KeyPhaseBit) {
|
||||
logger.Debugf("\tShort Header{DestConnectionID: %s, PacketNumber: %d, PacketNumberLen: %d, KeyPhase: %s}", dest, pn, pnLen, kp)
|
||||
}
|
||||
|
||||
@@ -21,12 +21,12 @@ var _ = Describe("Short Header", func() {
|
||||
0xde, 0xad, 0xbe, 0xef,
|
||||
0x13, 0x37, 0x99,
|
||||
}
|
||||
hdr, err := ParseShortHeader(data, 4)
|
||||
l, pn, pnLen, kp, err := ParseShortHeader(data, 4)
|
||||
Expect(err).ToNot(HaveOccurred())
|
||||
Expect(hdr.DestConnectionID).To(Equal(protocol.ParseConnectionID([]byte{0xde, 0xad, 0xbe, 0xef})))
|
||||
Expect(hdr.KeyPhase).To(Equal(protocol.KeyPhaseOne))
|
||||
Expect(hdr.PacketNumber).To(Equal(protocol.PacketNumber(0x133799)))
|
||||
Expect(hdr.PacketNumberLen).To(Equal(protocol.PacketNumberLen3))
|
||||
Expect(l).To(Equal(len(data)))
|
||||
Expect(kp).To(Equal(protocol.KeyPhaseOne))
|
||||
Expect(pn).To(Equal(protocol.PacketNumber(0x133799)))
|
||||
Expect(pnLen).To(Equal(protocol.PacketNumberLen3))
|
||||
})
|
||||
|
||||
It("errors when the QUIC bit is not set", func() {
|
||||
@@ -35,7 +35,7 @@ var _ = Describe("Short Header", func() {
|
||||
0xde, 0xad, 0xbe, 0xef,
|
||||
0x13, 0x37,
|
||||
}
|
||||
_, err := ParseShortHeader(data, 4)
|
||||
_, _, _, _, err := ParseShortHeader(data, 4)
|
||||
Expect(err).To(MatchError("not a QUIC packet"))
|
||||
})
|
||||
|
||||
@@ -45,14 +45,13 @@ var _ = Describe("Short Header", func() {
|
||||
0xde, 0xad, 0xbe, 0xef,
|
||||
0x13, 0x37,
|
||||
}
|
||||
hdr, err := ParseShortHeader(data, 4)
|
||||
_, pn, _, _, err := ParseShortHeader(data, 4)
|
||||
Expect(err).To(MatchError(ErrInvalidReservedBits))
|
||||
Expect(hdr).ToNot(BeNil())
|
||||
Expect(hdr.PacketNumber).To(Equal(protocol.PacketNumber(0x1337)))
|
||||
Expect(pn).To(Equal(protocol.PacketNumber(0x1337)))
|
||||
})
|
||||
|
||||
It("errors when passed a long header packet", func() {
|
||||
_, err := ParseShortHeader([]byte{0x80}, 4)
|
||||
_, _, _, _, err := ParseShortHeader([]byte{0x80}, 4)
|
||||
Expect(err).To(MatchError("not a short header packet"))
|
||||
})
|
||||
|
||||
@@ -62,10 +61,10 @@ var _ = Describe("Short Header", func() {
|
||||
0xde, 0xad, 0xbe, 0xef,
|
||||
0x13, 0x37, 0x99,
|
||||
}
|
||||
_, err := ParseShortHeader(data, 4)
|
||||
_, _, _, _, err := ParseShortHeader(data, 4)
|
||||
Expect(err).ToNot(HaveOccurred())
|
||||
for i := range data {
|
||||
_, err := ParseShortHeader(data[:i], 4)
|
||||
_, _, _, _, err := ParseShortHeader(data[:i], 4)
|
||||
Expect(err).To(MatchError(io.EOF))
|
||||
}
|
||||
})
|
||||
@@ -89,22 +88,9 @@ var _ = Describe("Short Header", func() {
|
||||
})
|
||||
|
||||
It("logs Short Headers containing a connection ID", func() {
|
||||
(&ShortHeader{
|
||||
DestConnectionID: protocol.ParseConnectionID([]byte{0xde, 0xad, 0xbe, 0xef, 0xca, 0xfe, 0x13, 0x37}),
|
||||
KeyPhase: protocol.KeyPhaseOne,
|
||||
PacketNumber: 1337,
|
||||
PacketNumberLen: 4,
|
||||
}).Log(logger)
|
||||
connID := protocol.ParseConnectionID([]byte{0xde, 0xad, 0xbe, 0xef, 0xca, 0xfe, 0x13, 0x37})
|
||||
LogShortHeader(logger, connID, 1337, protocol.PacketNumberLen4, protocol.KeyPhaseOne)
|
||||
Expect(buf.String()).To(ContainSubstring("Short Header{DestConnectionID: deadbeefcafe1337, PacketNumber: 1337, PacketNumberLen: 4, KeyPhase: 1}"))
|
||||
})
|
||||
})
|
||||
|
||||
It("determines the length", func() {
|
||||
Expect((&ShortHeader{
|
||||
DestConnectionID: protocol.ParseConnectionID([]byte{0xde, 0xaf}),
|
||||
PacketNumber: 0x1337,
|
||||
PacketNumberLen: protocol.PacketNumberLen3,
|
||||
KeyPhase: protocol.KeyPhaseOne,
|
||||
}).Len()).To(Equal(protocol.ByteCount(1 + 2 + 3)))
|
||||
})
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user