Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions server/internal/http/legacy/event/events.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,8 @@ const (
SYSTEM_INIT = "system/init"
SYSTEM_DISCONNECT = "system/disconnect"
SYSTEM_ERROR = "system/error"
SYSTEM_HEARTBEAT = "system/heartbeat"
SYSTEM_PONG = "system/pong"
)

const (
Expand Down
5 changes: 5 additions & 0 deletions server/internal/http/legacy/message/messages.go
Original file line number Diff line number Diff line change
Expand Up @@ -24,6 +24,11 @@ type SystemMessage struct {
Message string `json:"message"`
}

type SystemPong struct {
Event string `json:"event"`
Timestamp string `json:"timestamp"`
}

type SignalProvide struct {
Event string `json:"event"`
ID string `json:"id"`
Expand Down
10 changes: 7 additions & 3 deletions server/internal/http/legacy/wstobackend.go
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,9 @@ import (
"encoding/json"
"fmt"
"net/http"

"strconv"
"time"

"github.com/pion/webrtc/v3"

oldEvent "github.com/m1k1o/neko/server/internal/http/legacy/event"
Expand All @@ -28,8 +30,10 @@ func (s *session) wsToBackend(msg []byte) error {
switch header.Event {
// Client Events
case oldEvent.CLIENT_HEARTBEAT:
// do nothing
return nil
return s.toClient(&oldMessage.SystemPong{
Event: oldEvent.SYSTEM_PONG,
Timestamp: strconv.FormatInt(time.Now().UnixMilli(), 10),
})

// Signal Events
case oldEvent.SIGNAL_OFFER:
Expand Down
6 changes: 2 additions & 4 deletions server/internal/websocket/handler/handler.go
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package handler

import (
"time"
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"

Expand Down Expand Up @@ -39,9 +38,7 @@ func (h *MessageHandlerCtx) Message(session types.Session, data types.WebSocketM
switch data.Event {
// Client Events
case event.CLIENT_HEARTBEAT:
session.Send("system/heartbeat", map[string]any{
"timestamp": time.Now(),
})
err = h.systemPong(session)

// System Events
case event.SYSTEM_LOGS:
Expand Down Expand Up @@ -196,6 +193,7 @@ func (h *MessageHandlerCtx) Message(session types.Session, data types.WebSocketM
return h.sendBroadcast(session, payload)
})
default:
err = h.systemPong(session)
return false
}

Expand Down
11 changes: 11 additions & 0 deletions server/internal/websocket/handler/system.go
Original file line number Diff line number Diff line change
@@ -1,6 +1,7 @@
package handler

import (
"time"
"github.com/rs/zerolog"
"github.com/rs/zerolog/log"

Expand Down Expand Up @@ -94,3 +95,13 @@ func (h *MessageHandlerCtx) systemLogs(session types.Session, payload *message.S

return nil
}

func (h *MessageHandlerCtx) systemPong(session types.Session) error {
session.Send(
event.SYSTEM_PONG,
message.SystemPong{
Timestamp: time.Now().UnixMilli(),
},
)
return nil
}
4 changes: 2 additions & 2 deletions server/internal/websocket/manager.go
Original file line number Diff line number Diff line change
Expand Up @@ -32,8 +32,8 @@ var nologEvents = []string{
// don't log twice
event.SYSTEM_LOGS,
// don't log heartbeats
event.SYSTEM_HEARTBEAT,
event.CLIENT_HEARTBEAT,
// event.CLIENT_HEARTBEAT,
// event.SYSTEM_PONG,
// don't log every cursor update
event.SESSION_CURSORS,
}
Expand Down
1 change: 1 addition & 0 deletions server/pkg/types/event/events.go
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ const (
SYSTEM_LOGS = "system/logs"
SYSTEM_DISCONNECT = "system/disconnect"
SYSTEM_HEARTBEAT = "system/heartbeat"
SYSTEM_PONG = "system/pong"
)

const (
Expand Down
5 changes: 5 additions & 0 deletions server/pkg/types/message/messages.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,11 @@ type SystemSettingsUpdate struct {
types.Settings
}

// SystemPong is sent by the server as a direct response to CLIENT_HEARTBEAT
type SystemPong struct {
Timestamp int64 `json:"timestamp"` // Unix ms
}

/////////////////////////////
// Signal
/////////////////////////////
Expand Down