forked from External/mediamtx
rtmp: fix parsing error caused by extended timestamps (#2393) (#2556) (#2384) (#1550) (#2564) (#2808)
This commit is contained in:
parent
0c131a2e92
commit
89560c19a0
14 changed files with 430 additions and 228 deletions
|
|
@ -11,14 +11,14 @@ import (
|
|||
type Chunk0 struct {
|
||||
ChunkStreamID byte
|
||||
Timestamp uint32
|
||||
BodyLen uint32
|
||||
Type uint8
|
||||
MessageStreamID uint32
|
||||
BodyLen uint32
|
||||
Body []byte
|
||||
}
|
||||
|
||||
// Read reads the chunk.
|
||||
func (c *Chunk0) Read(r io.Reader, chunkMaxBodyLen uint32) error {
|
||||
func (c *Chunk0) Read(r io.Reader, maxBodyLen uint32, _ bool) error {
|
||||
header := make([]byte, 12)
|
||||
_, err := io.ReadFull(r, header)
|
||||
if err != nil {
|
||||
|
|
@ -31,9 +31,18 @@ func (c *Chunk0) Read(r io.Reader, chunkMaxBodyLen uint32) error {
|
|||
c.Type = header[7]
|
||||
c.MessageStreamID = uint32(header[8])<<24 | uint32(header[9])<<16 | uint32(header[10])<<8 | uint32(header[11])
|
||||
|
||||
if c.Timestamp >= 0xFFFFFF {
|
||||
_, err := io.ReadFull(r, header[:4])
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
c.Timestamp = uint32(header[0])<<24 | uint32(header[1])<<16 | uint32(header[2])<<8 | uint32(header[3])
|
||||
}
|
||||
|
||||
chunkBodyLen := c.BodyLen
|
||||
if chunkBodyLen > chunkMaxBodyLen {
|
||||
chunkBodyLen = chunkMaxBodyLen
|
||||
if chunkBodyLen > maxBodyLen {
|
||||
chunkBodyLen = maxBodyLen
|
||||
}
|
||||
|
||||
c.Body = make([]byte, chunkBodyLen)
|
||||
|
|
@ -41,21 +50,50 @@ func (c *Chunk0) Read(r io.Reader, chunkMaxBodyLen uint32) error {
|
|||
return err
|
||||
}
|
||||
|
||||
func (c Chunk0) marshalSize() int {
|
||||
n := 12 + len(c.Body)
|
||||
if c.Timestamp >= 0xFFFFFF {
|
||||
n += 4
|
||||
}
|
||||
return n
|
||||
}
|
||||
|
||||
// Marshal writes the chunk.
|
||||
func (c Chunk0) Marshal() ([]byte, error) {
|
||||
buf := make([]byte, 12+len(c.Body))
|
||||
func (c Chunk0) Marshal(_ bool) ([]byte, error) {
|
||||
buf := make([]byte, c.marshalSize())
|
||||
buf[0] = c.ChunkStreamID
|
||||
buf[1] = byte(c.Timestamp >> 16)
|
||||
buf[2] = byte(c.Timestamp >> 8)
|
||||
buf[3] = byte(c.Timestamp)
|
||||
buf[4] = byte(c.BodyLen >> 16)
|
||||
buf[5] = byte(c.BodyLen >> 8)
|
||||
buf[6] = byte(c.BodyLen)
|
||||
buf[7] = c.Type
|
||||
buf[8] = byte(c.MessageStreamID >> 24)
|
||||
buf[9] = byte(c.MessageStreamID >> 16)
|
||||
buf[10] = byte(c.MessageStreamID >> 8)
|
||||
buf[11] = byte(c.MessageStreamID)
|
||||
copy(buf[12:], c.Body)
|
||||
|
||||
if c.Timestamp >= 0xFFFFFF {
|
||||
buf[1] = 0xFF
|
||||
buf[2] = 0xFF
|
||||
buf[3] = 0xFF
|
||||
buf[4] = byte(c.BodyLen >> 16)
|
||||
buf[5] = byte(c.BodyLen >> 8)
|
||||
buf[6] = byte(c.BodyLen)
|
||||
buf[7] = c.Type
|
||||
buf[8] = byte(c.MessageStreamID >> 24)
|
||||
buf[9] = byte(c.MessageStreamID >> 16)
|
||||
buf[10] = byte(c.MessageStreamID >> 8)
|
||||
buf[11] = byte(c.MessageStreamID)
|
||||
buf[12] = byte(c.Timestamp >> 24)
|
||||
buf[13] = byte(c.Timestamp >> 16)
|
||||
buf[14] = byte(c.Timestamp >> 8)
|
||||
buf[15] = byte(c.Timestamp)
|
||||
copy(buf[16:], c.Body)
|
||||
} else {
|
||||
buf[1] = byte(c.Timestamp >> 16)
|
||||
buf[2] = byte(c.Timestamp >> 8)
|
||||
buf[3] = byte(c.Timestamp)
|
||||
buf[4] = byte(c.BodyLen >> 16)
|
||||
buf[5] = byte(c.BodyLen >> 8)
|
||||
buf[6] = byte(c.BodyLen)
|
||||
buf[7] = c.Type
|
||||
buf[8] = byte(c.MessageStreamID >> 24)
|
||||
buf[9] = byte(c.MessageStreamID >> 16)
|
||||
buf[10] = byte(c.MessageStreamID >> 8)
|
||||
buf[11] = byte(c.MessageStreamID)
|
||||
copy(buf[12:], c.Body)
|
||||
}
|
||||
|
||||
return buf, nil
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue