Fix GetMedias on stream reconnection issue
This commit is contained in:
@@ -171,8 +171,8 @@ func (p *Producer) reconnect(workerID, retry int) {
|
|||||||
|
|
||||||
log.Debug().Msgf("[streams] retry=%d to url=%s", retry, p.url)
|
log.Debug().Msgf("[streams] retry=%d to url=%s", retry, p.url)
|
||||||
|
|
||||||
var err error
|
conn, err := GetProducer(p.url)
|
||||||
if p.conn, err = GetProducer(p.url); err != nil {
|
if err != nil {
|
||||||
log.Debug().Msgf("[streams] producer=%s", err)
|
log.Debug().Msgf("[streams] producer=%s", err)
|
||||||
|
|
||||||
timeout := time.Minute
|
timeout := time.Minute
|
||||||
@@ -190,7 +190,7 @@ func (p *Producer) reconnect(workerID, retry int) {
|
|||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, media := range p.conn.GetMedias() {
|
for _, media := range conn.GetMedias() {
|
||||||
switch media.Direction {
|
switch media.Direction {
|
||||||
case core.DirectionRecvonly:
|
case core.DirectionRecvonly:
|
||||||
for _, receiver := range p.receivers {
|
for _, receiver := range p.receivers {
|
||||||
@@ -199,7 +199,7 @@ func (p *Producer) reconnect(workerID, retry int) {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
track, err := p.conn.GetTrack(media, codec)
|
track, err := conn.GetTrack(media, codec)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
@@ -215,12 +215,14 @@ func (p *Producer) reconnect(workerID, retry int) {
|
|||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
_ = p.conn.(core.Consumer).AddTrack(media, codec, sender)
|
_ = conn.(core.Consumer).AddTrack(media, codec, sender)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
go p.worker(p.conn, workerID)
|
p.conn = conn
|
||||||
|
|
||||||
|
go p.worker(conn, workerID)
|
||||||
}
|
}
|
||||||
|
|
||||||
func (p *Producer) stop() {
|
func (p *Producer) stop() {
|
||||||
|
|||||||
Reference in New Issue
Block a user