313 lines
6.9 KiB
Go
Raw Normal View History

2020-01-20 16:22:24 +00:00
package websocket
import (
2020-01-23 15:23:26 +00:00
"strings"
2021-10-05 22:38:24 +02:00
"m1k1o/neko/internal/types"
"m1k1o/neko/internal/types/event"
"m1k1o/neko/internal/types/message"
2020-01-20 16:22:24 +00:00
)
2021-11-16 22:50:11 +01:00
func (h *MessageHandler) adminLock(id string, session types.Session, payload *message.AdminLock) error {
2020-01-24 15:47:37 +00:00
if !session.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("user not admin")
return nil
}
2021-11-16 22:50:11 +01:00
_, ok := h.locked[payload.Resource]
if ok {
h.logger.Debug().Str("resource", payload.Resource).Msg("resource already locked...")
return nil
}
if payload.Resource != "login" && payload.Resource != "control" {
h.logger.Debug().Msg("unknown lock resource")
2020-01-20 16:22:24 +00:00
return nil
}
2021-11-16 22:50:11 +01:00
h.locked[payload.Resource] = id
2020-01-20 16:22:24 +00:00
if err := h.sessions.Broadcast(
2021-11-16 22:50:11 +01:00
message.AdminLock{
Event: event.ADMIN_LOCK,
ID: id,
Resource: payload.Resource,
2020-01-20 16:22:24 +00:00
}, nil); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_LOCK)
2020-01-20 16:22:24 +00:00
return err
}
return nil
}
2021-11-16 22:50:11 +01:00
func (h *MessageHandler) adminUnlock(id string, session types.Session, payload *message.AdminLock) error {
2020-01-24 15:47:37 +00:00
if !session.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("user not admin")
return nil
}
2021-11-16 22:50:11 +01:00
_, ok := h.locked[payload.Resource]
if !ok {
h.logger.Debug().Str("resource", payload.Resource).Msg("resource not locked...")
2020-01-20 16:22:24 +00:00
return nil
}
2021-11-16 22:50:11 +01:00
delete(h.locked, payload.Resource)
2020-01-20 16:22:24 +00:00
if err := h.sessions.Broadcast(
2021-11-16 22:50:11 +01:00
message.AdminLock{
Event: event.ADMIN_UNLOCK,
ID: id,
Resource: payload.Resource,
2020-01-20 16:22:24 +00:00
}, nil); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_UNLOCK)
2020-01-20 16:22:24 +00:00
return err
}
return nil
}
2020-01-24 15:47:37 +00:00
func (h *MessageHandler) adminControl(id string, session types.Session) error {
if !session.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("user not admin")
2020-01-20 16:22:24 +00:00
return nil
}
2020-01-22 17:16:40 +00:00
host, ok := h.sessions.GetHost()
2021-10-05 23:10:10 +02:00
err := h.sessions.SetHost(id)
if err != nil {
return err
}
2020-01-20 16:22:24 +00:00
2020-01-22 17:16:40 +00:00
if ok {
if err := h.sessions.Broadcast(
2020-01-22 17:16:40 +00:00
message.AdminTarget{
Event: event.ADMIN_CONTROL,
ID: id,
2020-01-24 15:47:37 +00:00
Target: host.ID(),
2020-01-22 17:16:40 +00:00
}, nil); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_CONTROL)
2020-01-22 17:16:40 +00:00
return err
}
} else {
if err := h.sessions.Broadcast(
2020-01-22 17:16:40 +00:00
message.Admin{
Event: event.ADMIN_CONTROL,
ID: id,
}, nil); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_CONTROL)
2020-01-22 17:16:40 +00:00
return err
}
2020-01-20 16:22:24 +00:00
}
return nil
}
2020-01-24 15:47:37 +00:00
func (h *MessageHandler) adminRelease(id string, session types.Session) error {
if !session.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("user not admin")
2020-01-20 16:22:24 +00:00
return nil
}
2020-01-22 17:16:40 +00:00
host, ok := h.sessions.GetHost()
2020-01-20 16:22:24 +00:00
h.sessions.ClearHost()
2020-01-22 17:16:40 +00:00
if ok {
if err := h.sessions.Broadcast(
2020-01-22 17:16:40 +00:00
message.AdminTarget{
Event: event.ADMIN_RELEASE,
ID: id,
2020-01-24 15:47:37 +00:00
Target: host.ID(),
2020-01-22 17:16:40 +00:00
}, nil); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_RELEASE)
2020-01-22 17:16:40 +00:00
return err
}
} else {
if err := h.sessions.Broadcast(
2020-01-22 17:16:40 +00:00
message.Admin{
Event: event.ADMIN_RELEASE,
ID: id,
}, nil); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_RELEASE)
2020-01-22 17:16:40 +00:00
return err
}
2020-01-20 16:22:24 +00:00
}
return nil
}
2020-01-24 15:47:37 +00:00
func (h *MessageHandler) adminGive(id string, session types.Session, payload *message.Admin) error {
if !session.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("user not admin")
2020-01-20 16:22:24 +00:00
return nil
}
2020-01-23 15:23:26 +00:00
if !h.sessions.Has(payload.ID) {
h.logger.Debug().Str("id", payload.ID).Msg("user does not exist")
2020-01-20 16:22:24 +00:00
return nil
}
2020-01-23 15:23:26 +00:00
// set host
2021-10-05 23:10:10 +02:00
err := h.sessions.SetHost(payload.ID)
if err != nil {
return err
}
2020-01-23 15:23:26 +00:00
// let everyone know
if err := h.sessions.Broadcast(
2020-01-23 15:23:26 +00:00
message.AdminTarget{
Event: event.CONTROL_GIVE,
ID: id,
Target: payload.ID,
}, nil); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.CONTROL_LOCKED)
2020-01-23 15:23:26 +00:00
return err
2020-01-22 17:16:40 +00:00
}
2020-01-23 15:23:26 +00:00
return nil
}
2020-01-24 15:47:37 +00:00
func (h *MessageHandler) adminMute(id string, session types.Session, payload *message.Admin) error {
if !session.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("user not admin")
2020-01-20 16:22:24 +00:00
return nil
}
2020-01-23 15:23:26 +00:00
target, ok := h.sessions.Get(payload.ID)
if !ok {
h.logger.Debug().Str("id", payload.ID).Msg("can't find session id")
return nil
}
2020-01-20 16:22:24 +00:00
2020-01-24 15:47:37 +00:00
if target.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("target is an admin, baling")
return nil
2020-01-20 16:22:24 +00:00
}
2020-01-24 15:47:37 +00:00
target.SetMuted(true)
2020-01-23 15:23:26 +00:00
if err := h.sessions.Broadcast(
2020-01-22 17:16:40 +00:00
message.AdminTarget{
2020-01-23 15:23:26 +00:00
Event: event.ADMIN_MUTE,
2020-01-24 15:47:37 +00:00
Target: target.ID(),
2020-01-22 17:16:40 +00:00
ID: id,
2020-01-20 16:22:24 +00:00
}, nil); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_UNMUTE)
2020-01-20 16:22:24 +00:00
return err
}
return nil
}
2020-01-24 15:47:37 +00:00
func (h *MessageHandler) adminUnmute(id string, session types.Session, payload *message.Admin) error {
if !session.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("user not admin")
2020-01-20 16:22:24 +00:00
return nil
}
2020-01-22 17:16:40 +00:00
target, ok := h.sessions.Get(payload.ID)
if !ok {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Str("id", payload.ID).Msg("can't find target session")
2020-01-22 17:16:40 +00:00
return nil
}
2020-01-24 15:47:37 +00:00
target.SetMuted(false)
2020-01-20 16:22:24 +00:00
if err := h.sessions.Broadcast(
2020-01-22 17:16:40 +00:00
message.AdminTarget{
2020-01-23 15:23:26 +00:00
Event: event.ADMIN_UNMUTE,
2020-01-24 15:47:37 +00:00
Target: target.ID(),
2020-01-22 17:16:40 +00:00
ID: id,
2020-01-20 16:22:24 +00:00
}, nil); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_UNMUTE)
2020-01-20 16:22:24 +00:00
return err
}
return nil
}
2020-01-24 15:47:37 +00:00
func (h *MessageHandler) adminKick(id string, session types.Session, payload *message.Admin) error {
if !session.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("user not admin")
2020-01-20 16:22:24 +00:00
return nil
}
2020-01-22 17:16:40 +00:00
target, ok := h.sessions.Get(payload.ID)
if !ok {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Str("id", payload.ID).Msg("can't find session id")
2020-01-22 17:16:40 +00:00
return nil
2020-01-20 16:22:24 +00:00
}
2020-01-24 15:47:37 +00:00
if target.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("target is an admin, baling")
2020-01-22 17:16:40 +00:00
return nil
}
if err := target.Kick("kicked"); err != nil {
2020-01-23 15:23:26 +00:00
return err
}
2020-01-22 17:16:40 +00:00
if err := h.sessions.Broadcast(
2020-01-22 17:16:40 +00:00
message.AdminTarget{
2020-01-23 15:23:26 +00:00
Event: event.ADMIN_KICK,
2020-01-24 15:47:37 +00:00
Target: target.ID(),
2020-01-22 17:16:40 +00:00
ID: id,
2020-01-23 15:23:26 +00:00
}, []string{payload.ID}); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_KICK)
2020-01-20 16:22:24 +00:00
return err
}
return nil
}
2020-01-24 15:47:37 +00:00
func (h *MessageHandler) adminBan(id string, session types.Session, payload *message.Admin) error {
if !session.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("user not admin")
2020-01-20 16:22:24 +00:00
return nil
}
2020-01-22 17:16:40 +00:00
target, ok := h.sessions.Get(payload.ID)
if !ok {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Str("id", payload.ID).Msg("can't find session id")
2020-01-22 17:16:40 +00:00
return nil
2020-01-20 16:22:24 +00:00
}
2020-01-24 15:47:37 +00:00
if target.Admin() {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("target is an admin, baling")
return nil
}
2020-01-24 15:47:37 +00:00
remote := target.Address()
2020-04-05 03:49:43 +00:00
if remote == "" {
2020-01-23 15:23:26 +00:00
h.logger.Debug().Msg("no remote address, baling")
return nil
}
2020-04-05 03:49:43 +00:00
address := strings.SplitN(remote, ":", -1)
2020-01-23 15:23:26 +00:00
if len(address[0]) < 1 {
2020-04-05 03:49:43 +00:00
h.logger.Debug().Str("address", remote).Msg("no remote address, baling")
2020-01-23 15:23:26 +00:00
return nil
}
2020-04-05 03:49:43 +00:00
h.logger.Debug().Str("address", remote).Msg("adding address to banned")
2021-11-17 22:10:55 +01:00
h.banned[address[0]] = id
2020-01-23 15:23:26 +00:00
if err := target.Kick("banned"); err != nil {
2020-01-23 15:23:26 +00:00
return err
}
2020-01-22 17:16:40 +00:00
if err := h.sessions.Broadcast(
2020-01-22 17:16:40 +00:00
message.AdminTarget{
2020-01-23 15:23:26 +00:00
Event: event.ADMIN_BAN,
2020-01-24 15:47:37 +00:00
Target: target.ID(),
2020-01-22 17:16:40 +00:00
ID: id,
2020-01-23 15:23:26 +00:00
}, []string{payload.ID}); err != nil {
h.logger.Warn().Err(err).Msgf("broadcasting event %s has failed", event.ADMIN_BAN)
2020-01-20 16:22:24 +00:00
return err
}
return nil
}