mirror of
https://github.com/m1k1o/neko.git
synced 2025-05-12 08:37:30 +02:00
system init WS.
This commit is contained in:
parent
745ef00cd2
commit
d00015ee91
4 changed files with 88 additions and 37 deletions
69
internal/websocket/handler/system.go
Normal file
69
internal/websocket/handler/system.go
Normal file
|
@ -0,0 +1,69 @@
|
|||
package handler
|
||||
|
||||
import (
|
||||
"demodesk/neko/internal/types"
|
||||
"demodesk/neko/internal/types/event"
|
||||
"demodesk/neko/internal/types/message"
|
||||
)
|
||||
|
||||
func (h *MessageHandlerCtx) systemInit(session types.Session) error {
|
||||
host := h.sessions.GetHost()
|
||||
|
||||
controlHost := message.ControlHost{
|
||||
HasHost: host != nil,
|
||||
}
|
||||
|
||||
if controlHost.HasHost {
|
||||
controlHost.HostID = host.ID()
|
||||
}
|
||||
|
||||
size := h.desktop.GetScreenSize()
|
||||
if size == nil {
|
||||
h.logger.Debug().Msg("could not get screen size")
|
||||
return nil
|
||||
}
|
||||
|
||||
members := []message.MemberData{}
|
||||
for _, session := range h.sessions.Members() {
|
||||
members = append(members, message.MemberData{
|
||||
ID: session.ID(),
|
||||
Name: session.Name(),
|
||||
IsAdmin: session.Admin(),
|
||||
})
|
||||
}
|
||||
|
||||
return session.Send(
|
||||
message.SystemInit{
|
||||
Event: event.SYSTEM_INIT,
|
||||
ControlHost: controlHost,
|
||||
Members: members,
|
||||
ScreenSize: message.ScreenSize{
|
||||
Width: size.Width,
|
||||
Height: size.Height,
|
||||
Rate: int(size.Rate),
|
||||
},
|
||||
})
|
||||
}
|
||||
|
||||
func (h *MessageHandlerCtx) systemAdmin(session types.Session) error {
|
||||
screenSizesList := []message.ScreenSize{}
|
||||
for _, size := range h.desktop.ScreenConfigurations() {
|
||||
for _, fps := range size.Rates {
|
||||
screenSizesList = append(screenSizesList, message.ScreenSize{
|
||||
Width: size.Width,
|
||||
Height: size.Height,
|
||||
Rate: int(fps),
|
||||
})
|
||||
}
|
||||
}
|
||||
|
||||
return session.Send(
|
||||
message.SystemAdmin{
|
||||
Event: event.SYSTEM_ADMIN,
|
||||
ScreenSizesList: screenSizesList,
|
||||
BroadcastStatus: message.BroadcastStatus{
|
||||
IsActive: h.capture.BroadcastEnabled(),
|
||||
URL: h.capture.BroadcastUrl(),
|
||||
},
|
||||
})
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue