neko/internal/websocket/handler/system.go

97 lines
2.2 KiB
Go
Raw Permalink Normal View History

2020-12-01 08:07:19 +13:00
package handler
import (
2021-09-10 08:08:39 +12:00
"github.com/rs/zerolog"
2021-09-10 08:51:37 +12:00
"github.com/rs/zerolog/log"
2021-09-10 08:08:39 +12:00
"github.com/demodesk/neko/pkg/types"
"github.com/demodesk/neko/pkg/types/event"
"github.com/demodesk/neko/pkg/types/message"
2020-12-01 08:07:19 +13:00
)
func (h *MessageHandlerCtx) systemInit(session types.Session) error {
host, hasHost := h.sessions.GetHost()
2020-12-01 08:07:19 +13:00
var hostID string
if hasHost {
hostID = host.ID()
2020-12-01 08:07:19 +13:00
}
controlHost := message.ControlHost{
HasHost: hasHost,
HostID: hostID,
2020-12-01 08:07:19 +13:00
}
2021-03-14 12:05:31 +13:00
sessions := map[string]message.SessionData{}
2021-03-14 09:11:48 +13:00
for _, session := range h.sessions.List() {
2021-03-14 11:32:10 +13:00
sessionId := session.ID()
2021-03-14 12:05:31 +13:00
sessions[sessionId] = message.SessionData{
2021-03-14 11:32:10 +13:00
ID: sessionId,
2021-03-14 12:45:51 +13:00
Profile: session.Profile(),
State: session.State(),
2020-12-02 10:56:08 +13:00
}
2020-12-01 08:07:19 +13:00
}
2021-09-02 07:58:39 +12:00
session.Send(
event.SYSTEM_INIT,
2020-12-01 08:07:19 +13:00
message.SystemInit{
2021-09-21 04:28:13 +12:00
SessionId: session.ID(),
ControlHost: controlHost,
ScreenSize: h.desktop.GetScreenSize(),
Sessions: sessions,
2022-03-27 12:08:06 +13:00
Settings: h.sessions.Settings(),
TouchEvents: h.desktop.HasTouchSupport(),
ScreencastEnabled: h.capture.Screencast().Enabled(),
2021-05-01 02:05:07 +12:00
WebRTC: message.SystemWebRTC{
Videos: h.capture.Video().IDs(),
2021-05-01 02:05:07 +12:00
},
2020-12-01 08:07:19 +13:00
})
2021-09-02 07:58:39 +12:00
return nil
2020-12-01 08:07:19 +13:00
}
func (h *MessageHandlerCtx) systemAdmin(session types.Session) error {
configurations := h.desktop.ScreenConfigurations()
list := make([]types.ScreenSize, 0, len(configurations))
for _, conf := range configurations {
list = append(list, types.ScreenSize{
Width: conf.Width,
Height: conf.Height,
Rate: conf.Rate,
})
2020-12-01 08:07:19 +13:00
}
broadcast := h.capture.Broadcast()
2021-09-02 07:58:39 +12:00
session.Send(
event.SYSTEM_ADMIN,
2020-12-01 08:07:19 +13:00
message.SystemAdmin{
ScreenSizesList: list, // TODO: remove
2020-12-01 08:07:19 +13:00
BroadcastStatus: message.BroadcastStatus{
2021-02-06 02:03:53 +13:00
IsActive: broadcast.Started(),
URL: broadcast.Url(),
2020-12-01 08:07:19 +13:00
},
})
2021-09-02 07:58:39 +12:00
return nil
2020-12-01 08:07:19 +13:00
}
2021-09-10 08:08:39 +12:00
func (h *MessageHandlerCtx) systemLogs(session types.Session, payload *message.SystemLogs) error {
2021-09-10 08:51:37 +12:00
for _, msg := range *payload {
level, _ := zerolog.ParseLevel(msg.Level)
2021-09-10 08:08:39 +12:00
2021-09-10 08:51:37 +12:00
if level < zerolog.DebugLevel || level > zerolog.ErrorLevel {
level = zerolog.NoLevel
}
// do not use handler logger context
log.WithLevel(level).
Fields(msg.Fields).
2021-09-13 03:00:29 +12:00
Str("module", "client").
2021-09-10 08:08:39 +12:00
Str("session_id", session.ID()).
2021-09-10 08:51:37 +12:00
Msg(msg.Message)
2021-09-10 08:08:39 +12:00
}
return nil
}