mirror of
https://github.com/m1k1o/neko.git
synced 2024-07-24 14:40:50 +12:00
remove admin from websockets.
This commit is contained in:
parent
994a91886d
commit
0a75950356
@ -54,9 +54,3 @@ const (
|
|||||||
const (
|
const (
|
||||||
BORADCAST_STATUS = "broadcast/status"
|
BORADCAST_STATUS = "broadcast/status"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
|
||||||
ADMIN_CONTROL = "admin/control" // TODO: Remove.
|
|
||||||
ADMIN_RELEASE = "admin/release" // TODO: Remove.
|
|
||||||
ADMIN_GIVE = "admin/give" // TODO: Remove.
|
|
||||||
)
|
|
||||||
|
@ -182,19 +182,6 @@ type ControlTarget struct {
|
|||||||
Target string `json:"target"`
|
Target string `json:"target"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// TODO: Remove.
|
|
||||||
type Admin struct {
|
|
||||||
Event string `json:"event"`
|
|
||||||
ID string `json:"id"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: Remove.
|
|
||||||
type AdminTarget struct {
|
|
||||||
Event string `json:"event"`
|
|
||||||
Target string `json:"target"`
|
|
||||||
ID string `json:"id"`
|
|
||||||
}
|
|
||||||
|
|
||||||
// TODO: Remove.
|
// TODO: Remove.
|
||||||
type ScreenResolution struct {
|
type ScreenResolution struct {
|
||||||
Event string `json:"event"`
|
Event string `json:"event"`
|
||||||
|
@ -1,85 +0,0 @@
|
|||||||
package handler
|
|
||||||
|
|
||||||
import (
|
|
||||||
"demodesk/neko/internal/types"
|
|
||||||
"demodesk/neko/internal/types/event"
|
|
||||||
"demodesk/neko/internal/types/message"
|
|
||||||
)
|
|
||||||
|
|
||||||
func (h *MessageHandlerCtx) adminControl(session types.Session) error {
|
|
||||||
if !session.Admin() {
|
|
||||||
h.logger.Debug().Msg("user not admin")
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
host := h.sessions.GetHost()
|
|
||||||
h.sessions.SetHost(session)
|
|
||||||
|
|
||||||
if host != nil {
|
|
||||||
h.sessions.Broadcast(
|
|
||||||
message.AdminTarget{
|
|
||||||
Event: event.ADMIN_CONTROL,
|
|
||||||
ID: session.ID(),
|
|
||||||
Target: host.ID(),
|
|
||||||
}, nil)
|
|
||||||
} else {
|
|
||||||
h.sessions.Broadcast(
|
|
||||||
message.Admin{
|
|
||||||
Event: event.ADMIN_CONTROL,
|
|
||||||
ID: session.ID(),
|
|
||||||
}, nil)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (h *MessageHandlerCtx) adminRelease(session types.Session) error {
|
|
||||||
if !session.Admin() {
|
|
||||||
h.logger.Debug().Msg("user not admin")
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
host := h.sessions.GetHost()
|
|
||||||
h.sessions.ClearHost()
|
|
||||||
|
|
||||||
if host != nil {
|
|
||||||
h.sessions.Broadcast(
|
|
||||||
message.AdminTarget{
|
|
||||||
Event: event.ADMIN_RELEASE,
|
|
||||||
ID: session.ID(),
|
|
||||||
Target: host.ID(),
|
|
||||||
}, nil)
|
|
||||||
} else {
|
|
||||||
h.sessions.Broadcast(
|
|
||||||
message.Admin{
|
|
||||||
Event: event.ADMIN_RELEASE,
|
|
||||||
ID: session.ID(),
|
|
||||||
}, nil)
|
|
||||||
}
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
func (h *MessageHandlerCtx) adminGive(session types.Session, payload *message.Admin) error {
|
|
||||||
if !session.Admin() {
|
|
||||||
h.logger.Debug().Msg("user not admin")
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
target, ok := h.sessions.Get(payload.ID)
|
|
||||||
if !ok {
|
|
||||||
h.logger.Debug().Str("id", payload.ID).Msg("can't find target session")
|
|
||||||
return nil
|
|
||||||
}
|
|
||||||
|
|
||||||
h.sessions.SetHost(target)
|
|
||||||
|
|
||||||
h.sessions.Broadcast(
|
|
||||||
message.AdminTarget{
|
|
||||||
Event: event.CONTROL_GIVE,
|
|
||||||
ID: session.ID(),
|
|
||||||
Target: target.ID(),
|
|
||||||
}, nil)
|
|
||||||
|
|
||||||
return nil
|
|
||||||
}
|
|
@ -84,17 +84,6 @@ func (h *MessageHandlerCtx) Message(session types.Session, raw []byte) error {
|
|||||||
err = utils.Unmarshal(payload, raw, func() error {
|
err = utils.Unmarshal(payload, raw, func() error {
|
||||||
return h.screenSizeChange(session, payload)
|
return h.screenSizeChange(session, payload)
|
||||||
})
|
})
|
||||||
|
|
||||||
// Admin Events
|
|
||||||
case event.ADMIN_CONTROL:
|
|
||||||
err = h.adminControl(session)
|
|
||||||
case event.ADMIN_RELEASE:
|
|
||||||
err = h.adminRelease(session)
|
|
||||||
case event.ADMIN_GIVE:
|
|
||||||
payload := &message.Admin{}
|
|
||||||
err = utils.Unmarshal(payload, raw, func() error {
|
|
||||||
return h.adminGive(session, payload)
|
|
||||||
})
|
|
||||||
default:
|
default:
|
||||||
return errors.Errorf("unknown message event %s", header.Event)
|
return errors.Errorf("unknown message event %s", header.Event)
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user