Files
monibuca/puller.go
2024-08-12 19:19:15 +08:00

88 lines
1.9 KiB
Go

package m7s
import (
"m7s.live/m7s/v5/pkg"
"m7s.live/m7s/v5/pkg/config"
)
type Connection struct {
pkg.MarcoTask
Plugin *Plugin
StreamPath string // 对应本地流
RemoteURL string // 远程服务器地址(用于推拉)
ReConnectCount int //重连次数
ConnectProxy string // 连接代理
}
func (client *Connection) reconnect(count int) (ok bool) {
ok = count == -1 || client.ReConnectCount <= count
client.ReConnectCount++
return
}
type Puller = func(*PullContext) error
func createPullContext(p *Plugin, streamPath string, url string) (pullCtx *PullContext) {
publishConfig := p.config.Publish
publishConfig.PublishTimeout = 0
pullCtx = &PullContext{
Pull: p.config.Pull,
publishConfig: &publishConfig,
}
pullCtx.Plugin = p
pullCtx.ConnectProxy = p.config.Pull.Proxy
pullCtx.RemoteURL = url
pullCtx.StreamPath = streamPath
pullCtx.Logger = p.Logger.With("pullURL", url, "streamPath", streamPath)
return
}
type PullContext struct {
Connection
Publisher *Publisher
publishConfig *config.Publish
config.Pull
}
func (p *PullContext) GetKey() string {
return p.StreamPath
}
type PullSubTask struct {
pkg.RetryTask
ctx *PullContext
Puller
}
func (p *PullSubTask) Start() (err error) {
p.MaxRetry = p.ctx.RePull
if p.ctx.Publisher, err = p.ctx.Plugin.PublishWithConfig(p.Context, p.ctx.StreamPath, *p.ctx.publishConfig); err != nil {
p.Error("pull publish failed", "error", err)
return
}
p.ctx.Publisher.OnDispose(func() {
p.Stop(p.ctx.Publisher.StopReason())
})
return p.Puller(p.ctx)
}
func (p *PullContext) Do(puller Puller) {
p.AddTask(&PullSubTask{ctx: p, Puller: puller})
}
func (p *PullContext) Start() (err error) {
s := p.Plugin.Server
if _, ok := s.Pulls.Get(p.GetKey()); ok {
return pkg.ErrStreamExist
}
s.Pulls.Add(p)
if p.Plugin.Meta.Puller != nil {
p.Do(p.Plugin.Meta.Puller)
}
return
}
func (p *PullContext) Dispose() {
p.Plugin.Server.Pulls.Remove(p)
}