mirror of
https://github.com/m1k1o/neko.git
synced 2025-05-21 21:17:04 +02:00
move server to server directory.
This commit is contained in:
parent
da45f62ca8
commit
cfb423b13d
211 changed files with 18 additions and 10 deletions
91
server/internal/websocket/peer.go
Normal file
91
server/internal/websocket/peer.go
Normal file
|
@ -0,0 +1,91 @@
|
|||
package websocket
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"errors"
|
||||
"sync"
|
||||
|
||||
"github.com/gorilla/websocket"
|
||||
"github.com/rs/zerolog"
|
||||
|
||||
"github.com/demodesk/neko/pkg/types"
|
||||
"github.com/demodesk/neko/pkg/types/event"
|
||||
"github.com/demodesk/neko/pkg/types/message"
|
||||
"github.com/demodesk/neko/pkg/utils"
|
||||
)
|
||||
|
||||
type WebSocketPeerCtx struct {
|
||||
mu sync.Mutex
|
||||
logger zerolog.Logger
|
||||
connection *websocket.Conn
|
||||
}
|
||||
|
||||
func newPeer(logger zerolog.Logger, connection *websocket.Conn) *WebSocketPeerCtx {
|
||||
return &WebSocketPeerCtx{
|
||||
logger: logger.With().Str("submodule", "peer").Logger(),
|
||||
connection: connection,
|
||||
}
|
||||
}
|
||||
|
||||
func (peer *WebSocketPeerCtx) Send(event string, payload any) {
|
||||
peer.mu.Lock()
|
||||
defer peer.mu.Unlock()
|
||||
|
||||
raw, err := json.Marshal(payload)
|
||||
if err != nil {
|
||||
peer.logger.Err(err).Str("event", event).Msg("message marshalling has failed")
|
||||
return
|
||||
}
|
||||
|
||||
err = peer.connection.WriteJSON(types.WebSocketMessage{
|
||||
Event: event,
|
||||
Payload: raw,
|
||||
})
|
||||
|
||||
if err != nil {
|
||||
err = errors.Unwrap(err) // unwrap if possible
|
||||
peer.logger.Warn().Err(err).Str("event", event).Msg("send message error")
|
||||
return
|
||||
}
|
||||
|
||||
// log events if not ignored
|
||||
if ok, _ := utils.ArrayIn(event, nologEvents); !ok {
|
||||
if len(raw) > maxPayloadLogLength {
|
||||
raw = []byte("<truncated>")
|
||||
}
|
||||
|
||||
peer.logger.Debug().
|
||||
Str("address", peer.connection.RemoteAddr().String()).
|
||||
Str("event", event).
|
||||
Str("payload", string(raw)).
|
||||
Msg("sending message to client")
|
||||
}
|
||||
}
|
||||
|
||||
func (peer *WebSocketPeerCtx) Ping() error {
|
||||
peer.mu.Lock()
|
||||
defer peer.mu.Unlock()
|
||||
|
||||
// application level heartbeat
|
||||
if err := peer.connection.WriteJSON(types.WebSocketMessage{
|
||||
Event: event.SYSTEM_HEARTBEAT,
|
||||
}); err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
return peer.connection.WriteMessage(websocket.PingMessage, nil)
|
||||
}
|
||||
|
||||
func (peer *WebSocketPeerCtx) Destroy(reason string) {
|
||||
peer.Send(
|
||||
event.SYSTEM_DISCONNECT,
|
||||
message.SystemDisconnect{
|
||||
Message: reason,
|
||||
})
|
||||
|
||||
peer.mu.Lock()
|
||||
defer peer.mu.Unlock()
|
||||
|
||||
err := peer.connection.Close()
|
||||
peer.logger.Err(err).Msg("peer connection destroyed")
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue