neko/neko.go

235 lines
5.2 KiB
Go
Raw Normal View History

package neko
import (
"fmt"
"os"
"os/signal"
"runtime"
2021-02-14 14:40:17 +01:00
"demodesk/neko/internal/api"
"demodesk/neko/internal/capture"
2020-11-01 16:09:48 +01:00
"demodesk/neko/internal/config"
"demodesk/neko/internal/desktop"
2021-02-14 14:40:17 +01:00
"demodesk/neko/internal/http"
2021-03-14 01:08:50 +01:00
"demodesk/neko/internal/member"
2020-11-01 16:09:48 +01:00
"demodesk/neko/internal/session"
2021-02-14 14:40:17 +01:00
"demodesk/neko/internal/webrtc"
2020-10-28 19:15:48 +01:00
"demodesk/neko/internal/websocket"
2020-12-12 18:37:19 +01:00
"demodesk/neko/modules"
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"
"github.com/spf13/cobra"
)
const Header = `&34
_ __ __
/ | / /__ / /______ \ /\
/ |/ / _ \/ //_/ __ \ ) ( ')
/ /| / __/ ,< / /_/ / ( / )
/_/ |_/\___/_/|_|\____/ \(__)|
&1&37 nurdism/m1k1o &33%s v%s&0
`
var (
//
buildDate = "dev"
//
gitCommit = "dev"
//
gitBranch = "dev"
2021-03-16 10:16:57 +01:00
// Major version when you make incompatible API changes.
major = "dev"
2021-03-16 10:16:57 +01:00
// Minor version when you add functionality in a backwards-compatible manner.
minor = "dev"
2021-03-16 10:16:57 +01:00
// Patch version when you make backwards-compatible bug fixes.
patch = "dev"
)
var Service *Neko
func init() {
Service = &Neko{
Version: &Version{
Major: major,
Minor: minor,
Patch: patch,
GitCommit: gitCommit,
GitBranch: gitBranch,
BuildDate: buildDate,
GoVersion: runtime.Version(),
Compiler: runtime.Compiler,
Platform: fmt.Sprintf("%s/%s", runtime.GOOS, runtime.GOARCH),
},
2020-10-31 16:40:33 +01:00
Configs: &Configs{
2021-02-14 14:40:17 +01:00
Root: &config.Root{},
Desktop: &config.Desktop{},
Capture: &config.Capture{},
WebRTC: &config.WebRTC{},
2021-03-14 01:08:50 +01:00
Member: &config.Member{},
2021-02-14 14:40:17 +01:00
Session: &config.Session{},
Server: &config.Server{},
2020-10-31 16:40:33 +01:00
},
}
}
type Version struct {
Major string
Minor string
Patch string
GitCommit string
GitBranch string
BuildDate string
GoVersion string
Compiler string
Platform string
}
func (i *Version) String() string {
return fmt.Sprintf("%s.%s.%s %s", i.Major, i.Minor, i.Patch, i.GitCommit)
}
func (i *Version) Details() string {
return fmt.Sprintf(
"%s\n%s\n%s\n%s\n%s\n%s\n%s\n",
fmt.Sprintf("Version %s.%s.%s", i.Major, i.Minor, i.Patch),
fmt.Sprintf("GitCommit %s", i.GitCommit),
fmt.Sprintf("GitBranch %s", i.GitBranch),
fmt.Sprintf("BuildDate %s", i.BuildDate),
fmt.Sprintf("GoVersion %s", i.GoVersion),
fmt.Sprintf("Compiler %s", i.Compiler),
fmt.Sprintf("Platform %s", i.Platform),
)
}
2020-10-31 16:40:33 +01:00
type Configs struct {
2021-02-14 14:40:17 +01:00
Root *config.Root
Desktop *config.Desktop
Capture *config.Capture
WebRTC *config.WebRTC
2021-03-14 01:08:50 +01:00
Member *config.Member
2021-02-14 14:40:17 +01:00
Session *config.Session
Server *config.Server
2020-10-31 16:40:33 +01:00
}
type Neko struct {
2021-02-14 14:40:17 +01:00
Version *Version
Configs *Configs
logger zerolog.Logger
desktopManager *desktop.DesktopManagerCtx
captureManager *capture.CaptureManagerCtx
webRTCManager *webrtc.WebRTCManagerCtx
2021-03-14 16:58:18 +01:00
memberManager *member.MemberManagerCtx
2021-02-14 14:40:17 +01:00
sessionManager *session.SessionManagerCtx
webSocketManager *websocket.WebSocketManagerCtx
apiManager *api.ApiManagerCtx
httpManager *http.HttpManagerCtx
}
func (neko *Neko) Preflight() {
neko.logger = log.With().Str("service", "neko").Logger()
}
func (neko *Neko) Start() {
2021-03-14 14:44:32 +01:00
neko.sessionManager = session.New(
neko.Configs.Session,
)
2021-03-14 01:08:50 +01:00
neko.memberManager = member.New(
2021-03-14 19:59:34 +01:00
neko.sessionManager,
2021-03-14 01:08:50 +01:00
neko.Configs.Member,
)
2021-03-14 14:44:32 +01:00
2021-03-14 01:08:50 +01:00
if err := neko.memberManager.Connect(); err != nil {
neko.logger.Panic().Err(err).Msg("unable to connect to member manager")
}
2020-11-01 16:09:48 +01:00
neko.desktopManager = desktop.New(
2020-11-04 00:27:47 +01:00
neko.Configs.Desktop,
2020-10-31 16:40:33 +01:00
)
2020-11-01 16:09:48 +01:00
neko.desktopManager.Start()
2020-11-01 16:09:48 +01:00
neko.captureManager = capture.New(
neko.desktopManager,
neko.Configs.Capture,
2020-10-31 16:40:33 +01:00
)
2020-11-01 16:09:48 +01:00
neko.captureManager.Start()
2020-10-31 16:40:33 +01:00
neko.webRTCManager = webrtc.New(
2020-11-01 16:09:48 +01:00
neko.desktopManager,
neko.captureManager,
2020-10-31 16:40:33 +01:00
neko.Configs.WebRTC,
)
neko.webRTCManager.Start()
2020-11-01 16:09:48 +01:00
neko.webSocketManager = websocket.New(
2020-10-31 16:40:33 +01:00
neko.sessionManager,
2020-11-01 16:09:48 +01:00
neko.desktopManager,
neko.captureManager,
2020-10-31 16:40:33 +01:00
neko.webRTCManager,
)
2020-11-01 16:09:48 +01:00
neko.webSocketManager.Start()
2020-10-31 16:40:33 +01:00
2020-11-01 16:54:06 +01:00
neko.apiManager = api.New(
neko.sessionManager,
2021-03-14 14:44:32 +01:00
neko.memberManager,
2020-11-01 16:54:06 +01:00
neko.desktopManager,
neko.captureManager,
neko.Configs.Server,
)
2020-12-12 18:37:19 +01:00
modules.Start(
neko.sessionManager,
neko.webSocketManager,
neko.apiManager,
)
2020-11-13 17:34:53 +01:00
neko.httpManager = http.New(
2020-11-01 16:09:48 +01:00
neko.webSocketManager,
2020-11-01 16:54:06 +01:00
neko.apiManager,
2020-10-31 16:40:33 +01:00
neko.Configs.Server,
2020-10-30 18:16:21 +01:00
)
2020-11-13 17:34:53 +01:00
neko.httpManager.Start()
}
func (neko *Neko) Shutdown() {
2021-09-01 23:30:09 +02:00
var err error
2021-03-14 01:08:50 +01:00
2021-09-01 23:30:09 +02:00
err = neko.memberManager.Disconnect()
neko.logger.Err(err).Msg("member manager disconnect")
2020-11-01 16:09:48 +01:00
2021-09-01 23:30:09 +02:00
err = neko.desktopManager.Shutdown()
neko.logger.Err(err).Msg("desktop manager shutdown")
2021-09-01 23:30:09 +02:00
err = neko.captureManager.Shutdown()
neko.logger.Err(err).Msg("capture manager shutdown")
2021-09-01 23:30:09 +02:00
err = neko.webRTCManager.Shutdown()
neko.logger.Err(err).Msg("webrtc manager shutdown")
2021-09-01 23:30:09 +02:00
err = neko.webSocketManager.Shutdown()
neko.logger.Err(err).Msg("websocket manager shutdown")
2020-12-12 18:37:19 +01:00
2021-09-01 23:30:09 +02:00
err = modules.Shutdown()
neko.logger.Err(err).Msg("modules shutdown")
err = neko.httpManager.Shutdown()
neko.logger.Err(err).Msg("http manager shutdown")
}
func (neko *Neko) ServeCommand(cmd *cobra.Command, args []string) {
neko.logger.Info().Msg("starting neko server")
neko.Start()
neko.logger.Info().Msg("neko ready")
quit := make(chan os.Signal, 1)
signal.Notify(quit, os.Interrupt)
sig := <-quit
2021-09-02 00:00:29 +02:00
neko.logger.Warn().Msgf("received %s, attempting graceful shutdown", sig)
neko.Shutdown()
neko.logger.Info().Msg("shutdown complete")
}