neko/internal/capture/broadcast.go

60 lines
1.3 KiB
Go
Raw Normal View History

2020-11-01 16:09:48 +01:00
package capture
import (
"demodesk/neko/internal/capture/gst"
)
func (manager *CaptureManagerCtx) StartBroadcast(url string) error {
manager.broadcast_url = url
manager.broadcasting = true
return manager.createBroadcastPipeline()
}
func (manager *CaptureManagerCtx) StopBroadcast() {
manager.broadcasting = false
manager.destroyBroadcastPipeline()
}
func (manager *CaptureManagerCtx) BroadcastEnabled() bool {
return manager.broadcasting
}
func (manager *CaptureManagerCtx) BroadcastUrl() string {
return manager.broadcast_url
}
func (manager *CaptureManagerCtx) createBroadcastPipeline() error {
2020-11-01 16:09:48 +01:00
var err error
manager.logger.Info().
Str("audio_device", manager.config.Device).
Str("video_display", manager.config.Display).
2020-11-01 17:34:47 +01:00
Str("broadcast_pipeline", manager.config.BroadcastPipeline).
2020-11-13 17:42:04 +01:00
Msgf("creating broadcast pipeline")
2020-11-01 16:09:48 +01:00
manager.broadcast, err = gst.CreateRTMPPipeline(
manager.config.Device,
manager.config.Display,
manager.config.BroadcastPipeline,
manager.broadcast_url,
)
if err != nil {
return err
2020-11-01 16:09:48 +01:00
}
manager.broadcast.Play()
2020-11-13 17:42:04 +01:00
manager.logger.Info().Msgf("starting broadcast pipeline")
return nil
2020-11-01 16:09:48 +01:00
}
func (manager *CaptureManagerCtx) destroyBroadcastPipeline() {
2020-11-01 17:34:47 +01:00
if manager.broadcast == nil {
2020-11-01 16:09:48 +01:00
return
}
2020-11-01 20:18:19 +01:00
manager.broadcast.Stop()
2020-11-13 17:42:04 +01:00
manager.logger.Info().Msgf("stopping broadcast pipeline")
2020-11-01 16:09:48 +01:00
manager.broadcast = nil
}