mirror of
https://github.com/nestriness/nestri.git
synced 2025-12-11 00:05:36 +02:00
## Description Whew, some stuff is still not re-implemented, but it's working! Rabbit's gonna explode with the amount of changes I reckon 😅 <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit - **New Features** - Introduced a peer-to-peer relay system using libp2p with enhanced stream forwarding, room state synchronization, and mDNS peer discovery. - Added decentralized room and participant management, metrics publishing, and safe, size-limited, concurrent message streaming with robust framing and callback dispatching. - Implemented asynchronous, callback-driven message handling over custom libp2p streams replacing WebSocket signaling. - **Improvements** - Migrated signaling and stream protocols from WebSocket to libp2p, improving reliability and scalability. - Simplified configuration and environment variables, removing deprecated flags and adding persistent data support. - Enhanced logging, error handling, and connection management for better observability and robustness. - Refined RTP header extension registration and NAT IP handling for improved WebRTC performance. - **Bug Fixes** - Improved ICE candidate buffering and SDP negotiation in WebRTC connections. - Fixed NAT IP and UDP port range configuration issues. - **Refactor** - Modularized codebase, reorganized relay and server logic, and removed deprecated WebSocket-based components. - Streamlined message structures, removed obsolete enums and message types, and simplified SafeMap concurrency. - Replaced WebSocket signaling with libp2p stream protocols in server and relay components. - **Chores** - Updated and cleaned dependencies across Go, Rust, and JavaScript packages. - Added `.gitignore` for persistent data directory in relay package. <!-- end of auto-generated comment: release notes by coderabbit.ai --> --------- Co-authored-by: DatCaptainHorse <DatCaptainHorse@users.noreply.github.com> Co-authored-by: Philipp Neumann <3daquawolf@gmail.com>
95 lines
1.9 KiB
Go
95 lines
1.9 KiB
Go
package connections
|
|
|
|
import (
|
|
"encoding/json"
|
|
"relay/internal/common"
|
|
|
|
"github.com/pion/webrtc/v4"
|
|
)
|
|
|
|
// MessageBase is the base type for any JSON message
|
|
type MessageBase struct {
|
|
Type string `json:"payload_type"`
|
|
Latency *common.LatencyTracker `json:"latency,omitempty"`
|
|
}
|
|
|
|
type MessageRaw struct {
|
|
MessageBase
|
|
Data json.RawMessage `json:"data"`
|
|
}
|
|
|
|
func NewMessageRaw(t string, data json.RawMessage) *MessageRaw {
|
|
return &MessageRaw{
|
|
MessageBase: MessageBase{
|
|
Type: t,
|
|
},
|
|
Data: data,
|
|
}
|
|
}
|
|
|
|
type MessageLog struct {
|
|
MessageBase
|
|
Level string `json:"level"`
|
|
Message string `json:"message"`
|
|
Time string `json:"time"`
|
|
}
|
|
|
|
func NewMessageLog(t string, level, message, time string) *MessageLog {
|
|
return &MessageLog{
|
|
MessageBase: MessageBase{
|
|
Type: t,
|
|
},
|
|
Level: level,
|
|
Message: message,
|
|
Time: time,
|
|
}
|
|
}
|
|
|
|
type MessageMetrics struct {
|
|
MessageBase
|
|
UsageCPU float64 `json:"usage_cpu"`
|
|
UsageMemory float64 `json:"usage_memory"`
|
|
Uptime uint64 `json:"uptime"`
|
|
PipelineLatency float64 `json:"pipeline_latency"`
|
|
}
|
|
|
|
func NewMessageMetrics(t string, usageCPU, usageMemory float64, uptime uint64, pipelineLatency float64) *MessageMetrics {
|
|
return &MessageMetrics{
|
|
MessageBase: MessageBase{
|
|
Type: t,
|
|
},
|
|
UsageCPU: usageCPU,
|
|
UsageMemory: usageMemory,
|
|
Uptime: uptime,
|
|
PipelineLatency: pipelineLatency,
|
|
}
|
|
}
|
|
|
|
type MessageICE struct {
|
|
MessageBase
|
|
Candidate webrtc.ICECandidateInit `json:"candidate"`
|
|
}
|
|
|
|
func NewMessageICE(t string, candidate webrtc.ICECandidateInit) *MessageICE {
|
|
return &MessageICE{
|
|
MessageBase: MessageBase{
|
|
Type: t,
|
|
},
|
|
Candidate: candidate,
|
|
}
|
|
}
|
|
|
|
type MessageSDP struct {
|
|
MessageBase
|
|
SDP webrtc.SessionDescription `json:"sdp"`
|
|
}
|
|
|
|
func NewMessageSDP(t string, sdp webrtc.SessionDescription) *MessageSDP {
|
|
return &MessageSDP{
|
|
MessageBase: MessageBase{
|
|
Type: t,
|
|
},
|
|
SDP: sdp,
|
|
}
|
|
}
|