mirror of
https://github.com/m1k1o/neko.git
synced 2024-07-24 14:40:50 +12:00
3e8d686c0f
* rewrite to use stream selector. * WIP. * add nacks to metrics. * add estimate trend. * estimator based on trend detector. * add estimator unstable duration. * add estimator debug. * add stalled duration. * estimator move values to config. * change default estimator values. * minor style changes. * fix websocket video messages. * replace video track with ivdeo id.
142 lines
3.0 KiB
Go
142 lines
3.0 KiB
Go
package handler
|
|
|
|
import (
|
|
"errors"
|
|
|
|
"github.com/demodesk/neko/pkg/types"
|
|
"github.com/demodesk/neko/pkg/types/event"
|
|
"github.com/demodesk/neko/pkg/types/message"
|
|
"github.com/pion/webrtc/v3"
|
|
)
|
|
|
|
func (h *MessageHandlerCtx) signalRequest(session types.Session, payload *message.SignalVideo) error {
|
|
if !session.Profile().CanWatch {
|
|
return errors.New("not allowed to watch")
|
|
}
|
|
|
|
// use default first video, if not provided
|
|
if payload.Video == "" {
|
|
videos := h.capture.Video().IDs()
|
|
payload.Video = videos[0]
|
|
}
|
|
|
|
offer, peer, err := h.webrtc.CreatePeer(session)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// set webrtc as paused if session has private mode enabled
|
|
if session.PrivateModeEnabled() {
|
|
peer.SetPaused(true)
|
|
}
|
|
|
|
// set video auto state
|
|
peer.SetVideoAuto(payload.Auto)
|
|
|
|
// set video stream
|
|
err = peer.SetVideo(types.StreamSelector{
|
|
ID: payload.Video,
|
|
Type: types.StreamSelectorTypeNearest,
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
session.Send(
|
|
event.SIGNAL_PROVIDE,
|
|
message.SignalProvide{
|
|
SDP: offer.SDP,
|
|
ICEServers: h.webrtc.ICEServers(),
|
|
})
|
|
|
|
return nil
|
|
}
|
|
|
|
func (h *MessageHandlerCtx) signalRestart(session types.Session) error {
|
|
peer := session.GetWebRTCPeer()
|
|
if peer == nil {
|
|
return errors.New("webRTC peer does not exist")
|
|
}
|
|
|
|
offer, err := peer.CreateOffer(true)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
// TODO: Use offer event instead.
|
|
session.Send(
|
|
event.SIGNAL_RESTART,
|
|
message.SignalDescription{
|
|
SDP: offer.SDP,
|
|
})
|
|
|
|
return nil
|
|
}
|
|
|
|
func (h *MessageHandlerCtx) signalOffer(session types.Session, payload *message.SignalDescription) error {
|
|
peer := session.GetWebRTCPeer()
|
|
if peer == nil {
|
|
return errors.New("webRTC peer does not exist")
|
|
}
|
|
|
|
err := peer.SetRemoteDescription(webrtc.SessionDescription{
|
|
SDP: payload.SDP,
|
|
Type: webrtc.SDPTypeOffer,
|
|
})
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
answer, err := peer.CreateAnswer()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
|
|
session.Send(
|
|
event.SIGNAL_ANSWER,
|
|
message.SignalDescription{
|
|
SDP: answer.SDP,
|
|
})
|
|
|
|
return nil
|
|
}
|
|
|
|
func (h *MessageHandlerCtx) signalAnswer(session types.Session, payload *message.SignalDescription) error {
|
|
peer := session.GetWebRTCPeer()
|
|
if peer == nil {
|
|
return errors.New("webRTC peer does not exist")
|
|
}
|
|
|
|
return peer.SetRemoteDescription(webrtc.SessionDescription{
|
|
SDP: payload.SDP,
|
|
Type: webrtc.SDPTypeAnswer,
|
|
})
|
|
}
|
|
|
|
func (h *MessageHandlerCtx) signalCandidate(session types.Session, payload *message.SignalCandidate) error {
|
|
peer := session.GetWebRTCPeer()
|
|
if peer == nil {
|
|
return errors.New("webRTC peer does not exist")
|
|
}
|
|
|
|
return peer.SetCandidate(payload.ICECandidateInit)
|
|
}
|
|
|
|
func (h *MessageHandlerCtx) signalVideo(session types.Session, payload *message.SignalVideo) error {
|
|
peer := session.GetWebRTCPeer()
|
|
if peer == nil {
|
|
return errors.New("webRTC peer does not exist")
|
|
}
|
|
|
|
peer.SetVideoAuto(payload.Auto)
|
|
|
|
if payload.Video != "" {
|
|
return peer.SetVideo(types.StreamSelector{
|
|
ID: payload.Video,
|
|
Type: types.StreamSelectorTypeNearest,
|
|
})
|
|
}
|
|
|
|
return nil
|
|
}
|