mirror of
https://github.com/m1k1o/neko.git
synced 2024-07-24 14:40:50 +12:00
316 lines
7.2 KiB
Go
316 lines
7.2 KiB
Go
package legacy
|
|
|
|
import (
|
|
"encoding/json"
|
|
"fmt"
|
|
"net/http"
|
|
|
|
"github.com/gorilla/websocket"
|
|
"github.com/pion/webrtc/v3"
|
|
|
|
oldEvent "github.com/demodesk/neko/internal/http/legacy/event"
|
|
oldMessage "github.com/demodesk/neko/internal/http/legacy/message"
|
|
|
|
"github.com/demodesk/neko/internal/api/room"
|
|
"github.com/demodesk/neko/internal/plugins/chat"
|
|
"github.com/demodesk/neko/internal/plugins/filetransfer"
|
|
"github.com/demodesk/neko/pkg/types"
|
|
"github.com/demodesk/neko/pkg/types/event"
|
|
"github.com/demodesk/neko/pkg/types/message"
|
|
)
|
|
|
|
func (s *session) wsToBackend(msg []byte, sendMsg func([]byte) error) error {
|
|
header := oldMessage.Message{}
|
|
err := json.Unmarshal(msg, &header)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
send := func(event string, payload any) error {
|
|
rawPayload, err := json.Marshal(payload)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
msg, err := json.Marshal(&types.WebSocketMessage{
|
|
Event: event,
|
|
Payload: rawPayload,
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return sendMsg(msg)
|
|
}
|
|
|
|
switch header.Event {
|
|
// Signal Events
|
|
case oldEvent.SIGNAL_OFFER:
|
|
request := &oldMessage.SignalOffer{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return send(event.SIGNAL_OFFER, &message.SignalDescription{
|
|
SDP: request.SDP,
|
|
})
|
|
|
|
case oldEvent.SIGNAL_ANSWER:
|
|
request := &oldMessage.SignalAnswer{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// TODO: Set Display Name here.
|
|
|
|
return send(event.SIGNAL_ANSWER, &message.SignalDescription{
|
|
SDP: request.SDP,
|
|
})
|
|
|
|
case oldEvent.SIGNAL_CANDIDATE:
|
|
request := &oldMessage.SignalCandidate{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
var candidate webrtc.ICECandidateInit
|
|
err = json.Unmarshal([]byte(request.Data), &candidate)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return send(event.SIGNAL_CANDIDATE, &message.SignalCandidate{
|
|
ICECandidateInit: candidate,
|
|
})
|
|
|
|
// Control Events
|
|
case oldEvent.CONTROL_RELEASE:
|
|
return send(event.CONTROL_RELEASE, nil)
|
|
|
|
case oldEvent.CONTROL_REQUEST:
|
|
return send(event.CONTROL_REQUEST, nil)
|
|
|
|
case oldEvent.CONTROL_GIVE:
|
|
request := &oldMessage.Control{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return s.apiReq(http.MethodPost, "/api/room/control/give/"+request.ID, nil, nil)
|
|
|
|
case oldEvent.CONTROL_CLIPBOARD:
|
|
request := &oldMessage.Clipboard{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return send(event.CLIPBOARD_SET, &message.ClipboardData{
|
|
Text: request.Text,
|
|
})
|
|
|
|
case oldEvent.CONTROL_KEYBOARD:
|
|
request := &oldMessage.Keyboard{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
if request.Layout != nil {
|
|
err = send(event.KEYBOARD_MAP, &message.KeyboardMap{
|
|
KeyboardMap: types.KeyboardMap{
|
|
Layout: *request.Layout,
|
|
},
|
|
})
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
if request.CapsLock != nil || request.NumLock != nil || request.ScrollLock != nil {
|
|
err = send(event.KEYBOARD_MODIFIERS, &message.KeyboardModifiers{
|
|
KeyboardModifiers: types.KeyboardModifiers{
|
|
CapsLock: request.CapsLock,
|
|
NumLock: request.NumLock,
|
|
// ScrollLock: request.ScrollLock, // ScrollLock is deprecated.
|
|
},
|
|
})
|
|
|
|
if err != nil {
|
|
return err
|
|
}
|
|
}
|
|
|
|
return nil
|
|
|
|
// Chat Events
|
|
case oldEvent.CHAT_MESSAGE:
|
|
request := &oldMessage.ChatReceive{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return send(chat.CHAT_MESSAGE, &chat.Content{
|
|
Text: request.Content,
|
|
})
|
|
|
|
case oldEvent.CHAT_EMOTE:
|
|
request := &oldMessage.EmoteReceive{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// loopback emote
|
|
msg, err := json.Marshal(&oldMessage.EmoteSend{
|
|
Event: oldEvent.CHAT_EMOTE,
|
|
ID: s.id,
|
|
Emote: request.Emote,
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// loopback emote
|
|
err = s.connClient.WriteMessage(websocket.TextMessage, msg)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// broadcast emote to other users
|
|
return send(event.SEND_BROADCAST, &message.SendBroadcast{
|
|
Sender: s.id,
|
|
Subject: "emote",
|
|
Body: request.Emote,
|
|
})
|
|
|
|
// File Transfer Events
|
|
case oldEvent.FILETRANSFER_REFRESH:
|
|
return send(filetransfer.FILETRANSFER_UPDATE, nil)
|
|
|
|
// Screen Events
|
|
case oldEvent.SCREEN_RESOLUTION:
|
|
// No WS equivalent, call HTTP API and return screen resolution.
|
|
return fmt.Errorf("event not implemented: %s", header.Event)
|
|
|
|
case oldEvent.SCREEN_CONFIGURATIONS:
|
|
// No WS equivalent, call HTTP API and return screen configurations.
|
|
return fmt.Errorf("event not implemented: %s", header.Event)
|
|
|
|
case oldEvent.SCREEN_SET:
|
|
request := &oldMessage.ScreenResolution{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return send(event.SCREEN_SET, &message.ScreenSize{
|
|
ScreenSize: types.ScreenSize{
|
|
Width: request.Width,
|
|
Height: request.Height,
|
|
Rate: request.Rate,
|
|
},
|
|
})
|
|
|
|
// Broadcast Events
|
|
case oldEvent.BROADCAST_CREATE:
|
|
request := &oldMessage.BroadcastCreate{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
return s.apiReq(http.MethodPost, "/api/room/broadcast/start", room.BroadcastStatusPayload{
|
|
URL: request.URL,
|
|
IsActive: true,
|
|
}, nil)
|
|
|
|
case oldEvent.BROADCAST_DESTROY:
|
|
return s.apiReq(http.MethodPost, "/api/room/broadcast/stop", nil, nil)
|
|
|
|
// Admin Events
|
|
case oldEvent.ADMIN_LOCK:
|
|
request := &oldMessage.AdminLock{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// TODO: No WS equivalent, call HTTP API.
|
|
return fmt.Errorf("event not implemented: %s", header.Event)
|
|
|
|
case oldEvent.ADMIN_UNLOCK:
|
|
request := &oldMessage.AdminLock{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// TODO: No WS equivalent, call HTTP API.
|
|
return fmt.Errorf("event not implemented: %s", header.Event)
|
|
|
|
case oldEvent.ADMIN_CONTROL:
|
|
return s.apiReq(http.MethodPost, "/api/room/control/take", nil, nil)
|
|
|
|
case oldEvent.ADMIN_RELEASE:
|
|
return s.apiReq(http.MethodPost, "/api/room/control/reset", nil, nil)
|
|
|
|
case oldEvent.ADMIN_GIVE:
|
|
request := &oldMessage.Admin{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
return s.apiReq(http.MethodPost, "/api/room/control/give/"+request.ID, nil, nil)
|
|
|
|
case oldEvent.ADMIN_BAN:
|
|
request := &oldMessage.Admin{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// TODO: No WS equivalent, call HTTP API.
|
|
return fmt.Errorf("event not implemented: %s", header.Event)
|
|
|
|
case oldEvent.ADMIN_KICK:
|
|
request := &oldMessage.Admin{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// TODO: No WS equivalent, call HTTP API.
|
|
return fmt.Errorf("event not implemented: %s", header.Event)
|
|
|
|
case oldEvent.ADMIN_MUTE:
|
|
request := &oldMessage.Admin{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// TODO: No WS equivalent, call HTTP API.
|
|
return fmt.Errorf("event not implemented: %s", header.Event)
|
|
|
|
case oldEvent.ADMIN_UNMUTE:
|
|
request := &oldMessage.Admin{}
|
|
err := json.Unmarshal(msg, request)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// TODO: No WS equivalent, call HTTP API.
|
|
return fmt.Errorf("event not implemented: %s", header.Event)
|
|
|
|
default:
|
|
return fmt.Errorf("unknown event type: %s", header.Event)
|
|
}
|
|
}
|