2020-10-22 16:54:50 +02:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
2022-01-14 00:21:56 +01:00
|
|
|
"os"
|
|
|
|
"os/signal"
|
|
|
|
|
|
|
|
"github.com/rs/zerolog"
|
2020-10-22 16:54:50 +02:00
|
|
|
"github.com/rs/zerolog/log"
|
|
|
|
"github.com/spf13/cobra"
|
|
|
|
|
2022-01-14 00:21:56 +01:00
|
|
|
"demodesk/neko/internal/api"
|
|
|
|
"demodesk/neko/internal/capture"
|
2022-01-16 20:35:57 +01:00
|
|
|
"demodesk/neko/internal/config"
|
2022-01-14 00:21:56 +01:00
|
|
|
"demodesk/neko/internal/desktop"
|
|
|
|
"demodesk/neko/internal/http"
|
|
|
|
"demodesk/neko/internal/member"
|
|
|
|
"demodesk/neko/internal/session"
|
|
|
|
"demodesk/neko/internal/webrtc"
|
|
|
|
"demodesk/neko/internal/websocket"
|
2021-02-14 14:40:17 +01:00
|
|
|
"demodesk/neko/modules"
|
2020-10-22 16:54:50 +02:00
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
2022-01-16 20:35:57 +01:00
|
|
|
service := serve{}
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2020-10-22 16:54:50 +02:00
|
|
|
command := &cobra.Command{
|
|
|
|
Use: "serve",
|
|
|
|
Short: "serve neko streaming server",
|
|
|
|
Long: `serve neko streaming server`,
|
2022-01-16 20:35:57 +01:00
|
|
|
Run: service.Command,
|
2020-10-22 16:54:50 +02:00
|
|
|
}
|
|
|
|
|
2022-01-14 00:22:23 +01:00
|
|
|
cobra.OnInitialize(service.Preflight)
|
2020-10-22 16:54:50 +02:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
if err := service.Init(command); err != nil {
|
|
|
|
log.Panic().Err(err).Msg("unable to initialize configuration")
|
|
|
|
}
|
|
|
|
|
2020-10-22 16:54:50 +02:00
|
|
|
root.AddCommand(command)
|
|
|
|
}
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
type serve struct {
|
|
|
|
logger zerolog.Logger
|
|
|
|
|
|
|
|
configs struct {
|
|
|
|
Root config.Root
|
|
|
|
Desktop config.Desktop
|
|
|
|
Capture config.Capture
|
|
|
|
WebRTC config.WebRTC
|
|
|
|
Member config.Member
|
|
|
|
Session config.Session
|
|
|
|
Server config.Server
|
|
|
|
}
|
|
|
|
|
|
|
|
managers struct {
|
|
|
|
desktop *desktop.DesktopManagerCtx
|
|
|
|
capture *capture.CaptureManagerCtx
|
|
|
|
webRTC *webrtc.WebRTCManagerCtx
|
|
|
|
member *member.MemberManagerCtx
|
|
|
|
session *session.SessionManagerCtx
|
|
|
|
webSocket *websocket.WebSocketManagerCtx
|
|
|
|
api *api.ApiManagerCtx
|
|
|
|
http *http.HttpManagerCtx
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func (c *serve) Init(cmd *cobra.Command) error {
|
|
|
|
if err := c.configs.Desktop.Init(cmd); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := c.configs.Capture.Init(cmd); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := c.configs.WebRTC.Init(cmd); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := c.configs.Member.Init(cmd); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := c.configs.Session.Init(cmd); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
if err := c.configs.Server.Init(cmd); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
for _, cfg := range modules.Configs() {
|
|
|
|
if err := cfg.Init(root); err != nil {
|
|
|
|
log.Panic().Err(err).Msg("unable to initialize configuration")
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return nil
|
2022-01-14 00:21:56 +01:00
|
|
|
}
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
func (c *serve) Preflight() {
|
|
|
|
c.logger = log.With().Str("service", "neko").Logger()
|
|
|
|
|
|
|
|
c.configs.Desktop.Set()
|
|
|
|
c.configs.Capture.Set()
|
|
|
|
c.configs.WebRTC.Set()
|
|
|
|
c.configs.Member.Set()
|
|
|
|
c.configs.Session.Set()
|
|
|
|
c.configs.Server.Set()
|
|
|
|
|
|
|
|
for _, cfg := range modules.Configs() {
|
|
|
|
cfg.Set()
|
|
|
|
}
|
2022-01-14 00:21:56 +01:00
|
|
|
}
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
func (c *serve) Start() {
|
|
|
|
c.managers.session = session.New(
|
|
|
|
&c.configs.Session,
|
2022-01-14 00:21:56 +01:00
|
|
|
)
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.member = member.New(
|
|
|
|
c.managers.session,
|
|
|
|
&c.configs.Member,
|
2022-01-14 00:21:56 +01:00
|
|
|
)
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
if err := c.managers.member.Connect(); err != nil {
|
|
|
|
c.logger.Panic().Err(err).Msg("unable to connect to member manager")
|
2022-01-14 00:21:56 +01:00
|
|
|
}
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.desktop = desktop.New(
|
|
|
|
&c.configs.Desktop,
|
2022-01-14 00:21:56 +01:00
|
|
|
)
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.desktop.Start()
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.capture = capture.New(
|
|
|
|
c.managers.desktop,
|
|
|
|
&c.configs.Capture,
|
2022-01-14 00:21:56 +01:00
|
|
|
)
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.capture.Start()
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.webRTC = webrtc.New(
|
|
|
|
c.managers.desktop,
|
|
|
|
c.managers.capture,
|
|
|
|
&c.configs.WebRTC,
|
2022-01-14 00:21:56 +01:00
|
|
|
)
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.webRTC.Start()
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.webSocket = websocket.New(
|
|
|
|
c.managers.session,
|
|
|
|
c.managers.desktop,
|
|
|
|
c.managers.capture,
|
|
|
|
c.managers.webRTC,
|
2022-01-14 00:21:56 +01:00
|
|
|
)
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.webSocket.Start()
|
|
|
|
|
|
|
|
c.managers.api = api.New(
|
|
|
|
c.managers.session,
|
|
|
|
c.managers.member,
|
|
|
|
c.managers.desktop,
|
|
|
|
c.managers.capture,
|
|
|
|
&c.configs.Server,
|
2022-01-14 00:21:56 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
modules.Start(
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.session,
|
|
|
|
c.managers.webSocket,
|
|
|
|
c.managers.api,
|
2022-01-14 00:21:56 +01:00
|
|
|
)
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.http = http.New(
|
|
|
|
c.managers.webSocket,
|
|
|
|
c.managers.api,
|
|
|
|
&c.configs.Server,
|
2022-01-14 00:21:56 +01:00
|
|
|
)
|
2022-01-16 20:35:57 +01:00
|
|
|
c.managers.http.Start()
|
2022-01-14 00:21:56 +01:00
|
|
|
}
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
func (c *serve) Shutdown() {
|
2022-01-14 00:21:56 +01:00
|
|
|
var err error
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
err = c.managers.member.Disconnect()
|
|
|
|
c.logger.Err(err).Msg("member manager disconnect")
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
err = c.managers.desktop.Shutdown()
|
|
|
|
c.logger.Err(err).Msg("desktop manager shutdown")
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
err = c.managers.capture.Shutdown()
|
|
|
|
c.logger.Err(err).Msg("capture manager shutdown")
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
err = c.managers.webRTC.Shutdown()
|
|
|
|
c.logger.Err(err).Msg("webrtc manager shutdown")
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
err = c.managers.webSocket.Shutdown()
|
|
|
|
c.logger.Err(err).Msg("websocket manager shutdown")
|
2022-01-14 00:21:56 +01:00
|
|
|
|
|
|
|
err = modules.Shutdown()
|
2022-01-16 20:35:57 +01:00
|
|
|
c.logger.Err(err).Msg("modules shutdown")
|
2022-01-14 00:21:56 +01:00
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
err = c.managers.http.Shutdown()
|
|
|
|
c.logger.Err(err).Msg("http manager shutdown")
|
2022-01-14 00:21:56 +01:00
|
|
|
}
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
func (c *serve) Command(cmd *cobra.Command, args []string) {
|
|
|
|
c.logger.Info().Msg("starting neko server")
|
|
|
|
c.Start()
|
|
|
|
c.logger.Info().Msg("neko ready")
|
2022-01-14 00:21:56 +01:00
|
|
|
|
|
|
|
quit := make(chan os.Signal, 1)
|
|
|
|
signal.Notify(quit, os.Interrupt)
|
|
|
|
sig := <-quit
|
|
|
|
|
2022-01-16 20:35:57 +01:00
|
|
|
c.logger.Warn().Msgf("received %s, attempting graceful shutdown", sig)
|
|
|
|
c.Shutdown()
|
|
|
|
c.logger.Info().Msg("shutdown complete")
|
2022-01-14 00:21:56 +01:00
|
|
|
}
|