Fix RTSP backchannel processing
This commit is contained in:
@@ -7,6 +7,7 @@ import (
|
|||||||
"github.com/AlexxIT/go2rtc/pkg/h265"
|
"github.com/AlexxIT/go2rtc/pkg/h265"
|
||||||
"github.com/AlexxIT/go2rtc/pkg/mjpeg"
|
"github.com/AlexxIT/go2rtc/pkg/mjpeg"
|
||||||
"github.com/pion/rtp"
|
"github.com/pion/rtp"
|
||||||
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
func (c *Conn) GetMedias() []*core.Media {
|
func (c *Conn) GetMedias() []*core.Media {
|
||||||
@@ -41,6 +42,8 @@ func (c *Conn) AddTrack(media *core.Media, codec *core.Codec, track *core.Receiv
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
c.state = StateSetup
|
||||||
|
|
||||||
case core.ModePassiveConsumer:
|
case core.ModePassiveConsumer:
|
||||||
channel = byte(len(c.senders)) * 2
|
channel = byte(len(c.senders)) * 2
|
||||||
|
|
||||||
@@ -85,6 +88,10 @@ func (c *Conn) packetWriter(codec *core.Codec, channel uint8) core.HandlerFunc {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if err := c.conn.SetWriteDeadline(time.Now().Add(Timeout)); err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
n, err := c.conn.Write(data)
|
n, err := c.conn.Write(data)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
|
|||||||
@@ -130,6 +130,11 @@ func (c *Conn) Reconnect() error {
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
for _, sender := range c.senders {
|
||||||
|
if _, err := c.SetupMedia(sender.Media); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user