remove lengths from public header struct

This commit is contained in:
Lucas Clemente
2016-04-10 20:02:35 +02:00
parent 551d5798e4
commit 07f5daa7ba
3 changed files with 20 additions and 29 deletions

View File

@@ -6,7 +6,6 @@ import (
)
// A StreamFrame of QUIC
// TODO: Maybe remove unneeded stuff, e.g. lengths?
type StreamFrame struct {
FinBit bool
StreamID uint32

View File

@@ -1,19 +1,17 @@
package quic
import "io"
import (
"bytes"
"io"
)
// The PublicHeader of a QUIC packet
type PublicHeader struct {
VersionFlag bool
ResetFlag bool
ConnectionIDLength uint8
ConnectionID uint64
QuicVersion uint32
PacketNumberLength uint8
PacketNumber uint64
VersionFlag bool
ResetFlag bool
ConnectionID uint64
QuicVersion uint32
PacketNumber uint64
}
// ParsePublicHeader parses a QUIC packet's public header
@@ -27,27 +25,29 @@ func ParsePublicHeader(b io.ByteReader) (*PublicHeader, error) {
}
header.VersionFlag = publicFlagByte&0x01 > 0
header.ResetFlag = publicFlagByte&0x02 > 0
var connectionIDLen, packetNumberLen uint8
switch publicFlagByte & 0x0C {
case 0x0C:
header.ConnectionIDLength = 8
connectionIDLen = 8
case 0x08:
header.ConnectionIDLength = 4
connectionIDLen = 4
case 0x04:
header.ConnectionIDLength = 1
connectionIDLen = 1
}
switch publicFlagByte & 0x30 {
case 0x30:
header.PacketNumberLength = 6
packetNumberLen = 6
case 0x20:
header.PacketNumberLength = 4
packetNumberLen = 4
case 0x10:
header.PacketNumberLength = 2
packetNumberLen = 2
case 0x00:
header.PacketNumberLength = 1
packetNumberLen = 1
}
// Connection ID
header.ConnectionID, err = readUintN(b, header.ConnectionIDLength)
header.ConnectionID, err = readUintN(b, connectionIDLen)
if err != nil {
return nil, err
}
@@ -63,7 +63,7 @@ func ParsePublicHeader(b io.ByteReader) (*PublicHeader, error) {
}
// Packet number
header.PacketNumber, err = readUintN(b, header.PacketNumberLength)
header.PacketNumber, err = readUintN(b, packetNumberLen)
if err != nil {
return nil, err
}

View File

@@ -16,10 +16,8 @@ var _ = Describe("Public Header", func() {
Expect(err).ToNot(HaveOccurred())
Expect(publicHeader.VersionFlag).To(BeTrue())
Expect(publicHeader.ResetFlag).To(BeFalse())
Expect(publicHeader.ConnectionIDLength).To(Equal(uint8(8)))
Expect(publicHeader.ConnectionID).To(Equal(uint64(0xf61986669b9ffa4c)))
Expect(publicHeader.QuicVersion).To(Equal(binary.BigEndian.Uint32([]byte("Q030"))))
Expect(publicHeader.PacketNumberLength).To(Equal(uint8(1)))
Expect(publicHeader.PacketNumber).To(Equal(uint64(1)))
Expect(b.Len()).To(BeZero())
})
@@ -29,7 +27,6 @@ var _ = Describe("Public Header", func() {
publicHeader, err := ParsePublicHeader(b)
Expect(err).ToNot(HaveOccurred())
Expect(publicHeader.VersionFlag).To(BeFalse())
Expect(publicHeader.ConnectionIDLength).To(Equal(uint8(4)))
Expect(publicHeader.ConnectionID).To(Equal(uint64(0x9b9ffa4c)))
Expect(b.Len()).To(BeZero())
})
@@ -39,7 +36,6 @@ var _ = Describe("Public Header", func() {
publicHeader, err := ParsePublicHeader(b)
Expect(err).ToNot(HaveOccurred())
Expect(publicHeader.VersionFlag).To(BeFalse())
Expect(publicHeader.ConnectionIDLength).To(Equal(uint8(1)))
Expect(publicHeader.ConnectionID).To(Equal(uint64(0x4c)))
Expect(b.Len()).To(BeZero())
})
@@ -49,7 +45,6 @@ var _ = Describe("Public Header", func() {
publicHeader, err := ParsePublicHeader(b)
Expect(err).ToNot(HaveOccurred())
Expect(publicHeader.VersionFlag).To(BeFalse())
Expect(publicHeader.ConnectionIDLength).To(Equal(uint8(0)))
Expect(b.Len()).To(BeZero())
})
@@ -57,7 +52,6 @@ var _ = Describe("Public Header", func() {
b := bytes.NewReader([]byte{0x10, 0xde, 0xca})
publicHeader, err := ParsePublicHeader(b)
Expect(err).ToNot(HaveOccurred())
Expect(publicHeader.PacketNumberLength).To(Equal(uint8(2)))
Expect(publicHeader.PacketNumber).To(Equal(uint64(0xdeca)))
Expect(b.Len()).To(BeZero())
})
@@ -66,7 +60,6 @@ var _ = Describe("Public Header", func() {
b := bytes.NewReader([]byte{0x20, 0xde, 0xca, 0xfb, 0xad})
publicHeader, err := ParsePublicHeader(b)
Expect(err).ToNot(HaveOccurred())
Expect(publicHeader.PacketNumberLength).To(Equal(uint8(4)))
Expect(publicHeader.PacketNumber).To(Equal(uint64(0xdecafbad)))
Expect(b.Len()).To(BeZero())
})
@@ -75,7 +68,6 @@ var _ = Describe("Public Header", func() {
b := bytes.NewReader([]byte{0x30, 0xde, 0xca, 0xfb, 0xad, 0x42, 0x23})
publicHeader, err := ParsePublicHeader(b)
Expect(err).ToNot(HaveOccurred())
Expect(publicHeader.PacketNumberLength).To(Equal(uint8(6)))
Expect(publicHeader.PacketNumber).To(Equal(uint64(0xdecafbad4223)))
Expect(b.Len()).To(BeZero())
})