2020-04-06 03:42:42 +00:00
|
|
|
package broadcast
|
|
|
|
|
|
|
|
import (
|
|
|
|
"github.com/rs/zerolog"
|
2020-04-18 20:57:28 +00:00
|
|
|
"github.com/rs/zerolog/log"
|
2020-04-06 03:42:42 +00:00
|
|
|
"n.eko.moe/neko/internal/gst"
|
|
|
|
"n.eko.moe/neko/internal/types/config"
|
|
|
|
)
|
|
|
|
|
|
|
|
type BroadcastManager struct {
|
|
|
|
logger zerolog.Logger
|
|
|
|
pipeline *gst.Pipeline
|
|
|
|
config *config.Broadcast
|
|
|
|
}
|
|
|
|
|
|
|
|
func New(config *config.Broadcast) *BroadcastManager {
|
|
|
|
return &BroadcastManager{
|
2020-04-18 20:57:28 +00:00
|
|
|
logger: log.With().Str("module", "remote").Logger(),
|
|
|
|
config: config,
|
2020-04-06 03:42:42 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (manager *BroadcastManager) Start() {
|
|
|
|
var err error
|
|
|
|
manager.pipeline, err = gst.CreateRTMPPipeline(
|
|
|
|
manager.config.Device,
|
|
|
|
manager.config.Display,
|
|
|
|
manager.config.RTMP,
|
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
manager.logger.Panic().Err(err).Msg("unable to create rtmp pipeline")
|
2020-04-18 20:57:28 +00:00
|
|
|
}
|
2020-04-06 03:42:42 +00:00
|
|
|
|
2020-04-18 20:57:28 +00:00
|
|
|
manager.pipeline.Start()
|
2020-04-06 03:42:42 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
func (manager *BroadcastManager) Shutdown() error {
|
2020-04-18 20:57:28 +00:00
|
|
|
if manager.pipeline != nil {
|
|
|
|
manager.pipeline.Stop()
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
2020-04-06 03:42:42 +00:00
|
|
|
}
|