mirror of
https://github.com/balzack/databag.git
synced 2025-02-12 03:29:16 +00:00
preparing webrtc signaling layer
This commit is contained in:
parent
7affec0006
commit
d2c7dcd06a
@ -3649,6 +3649,11 @@ paths:
|
|||||||
description: account disabled
|
description: account disabled
|
||||||
'500':
|
'500':
|
||||||
description: internal server error
|
description: internal server error
|
||||||
|
requestBody:
|
||||||
|
content:
|
||||||
|
application/json:
|
||||||
|
schema:
|
||||||
|
type: string
|
||||||
|
|
||||||
/talk/calls/{callId}:
|
/talk/calls/{callId}:
|
||||||
put:
|
put:
|
||||||
|
@ -1,9 +1,70 @@
|
|||||||
package databag
|
package databag
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"databag/internal/store"
|
||||||
|
"github.com/google/uuid"
|
||||||
|
"encoding/hex"
|
||||||
|
"github.com/theckman/go-securerandom"
|
||||||
|
"gorm.io/gorm"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
//AddCall adds an active call with ice signal and relay
|
//AddCall adds an active call with ice signal and relay
|
||||||
func AddCall(w http.ResponseWriter, r *http.Request) {
|
func AddCall(w http.ResponseWriter, r *http.Request) {
|
||||||
|
|
||||||
|
account, code, err := ParamAgentToken(r, false)
|
||||||
|
if err != nil {
|
||||||
|
ErrResponse(w, code, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
var cardId string
|
||||||
|
if err := ParseRequest(r, w, &cardId); err != nil {
|
||||||
|
ErrResponse(w, http.StatusBadRequest, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// verify card is present
|
||||||
|
var cardSlot store.CardSlot
|
||||||
|
if err := store.DB.Preload("Card.CardSlot").Where("account_id = ? AND card_slot_id = ?", account.ID, cardId).First(&cardSlot).Error; err != nil {
|
||||||
|
if !errors.Is(err, gorm.ErrRecordNotFound) {
|
||||||
|
ErrResponse(w, http.StatusInternalServerError, err)
|
||||||
|
} else {
|
||||||
|
ErrResponse(w, http.StatusNotFound, err)
|
||||||
|
}
|
||||||
|
return
|
||||||
|
}
|
||||||
|
if cardSlot.Card == nil {
|
||||||
|
ErrResponse(w, http.StatusNotFound, errors.New("card has been deleted"))
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// generate call params
|
||||||
|
callerBin, callerErr := securerandom.Bytes(APPTokenSize)
|
||||||
|
if callerErr != nil {
|
||||||
|
ErrResponse(w, http.StatusInternalServerError, callerErr)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
calleeBin, calleeErr := securerandom.Bytes(APPTokenSize)
|
||||||
|
if calleeErr != nil {
|
||||||
|
ErrResponse(w, http.StatusInternalServerError, calleeErr)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
callId := uuid.New().String()
|
||||||
|
|
||||||
|
// allocate bridge
|
||||||
|
callerToken := hex.EncodeToString(callerBin);
|
||||||
|
calleeToken := hex.EncodeToString(calleeBin);
|
||||||
|
bridgeRelay.AddBridge(callId, callerToken, calleeToken);
|
||||||
|
|
||||||
|
// create response
|
||||||
|
call := Call{
|
||||||
|
Id: callId,
|
||||||
|
CardId: cardId,
|
||||||
|
CallerToken: callerToken,
|
||||||
|
CalleeToken: calleeToken,
|
||||||
|
KeepAlive: BridgeKeepAlive,
|
||||||
|
}
|
||||||
|
WriteResponse(w, call);
|
||||||
}
|
}
|
||||||
|
@ -7,7 +7,6 @@ import (
|
|||||||
"errors"
|
"errors"
|
||||||
)
|
)
|
||||||
|
|
||||||
var bridgeRelay BridgeRelay;
|
|
||||||
var relayUpgrader = websocket.Upgrader{}
|
var relayUpgrader = websocket.Upgrader{}
|
||||||
|
|
||||||
//Status handler for websocket connection
|
//Status handler for websocket connection
|
||||||
|
@ -7,14 +7,15 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
const bridgeKeepAlive = 6
|
var bridgeRelay BridgeRelay;
|
||||||
|
const BridgeKeepAlive = 6
|
||||||
|
|
||||||
type BridgeStatus struct {
|
type BridgeStatus struct {
|
||||||
status string
|
status string
|
||||||
}
|
}
|
||||||
|
|
||||||
type Bridge struct {
|
type Bridge struct {
|
||||||
bridgeId string
|
callId string
|
||||||
expires int64
|
expires int64
|
||||||
callerToken string
|
callerToken string
|
||||||
calleeToken string
|
calleeToken string
|
||||||
@ -27,12 +28,12 @@ type BridgeRelay struct {
|
|||||||
bridges []Bridge
|
bridges []Bridge
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s BridgeRelay) AddBridge(bridgeId string, callerToken string, calleeToken string) {
|
func (s *BridgeRelay) AddBridge(callId string, callerToken string, calleeToken string) {
|
||||||
s.sync.Lock()
|
s.sync.Lock()
|
||||||
defer s.sync.Unlock()
|
defer s.sync.Unlock()
|
||||||
bridge := Bridge{
|
bridge := Bridge{
|
||||||
bridgeId: bridgeId,
|
callId: callId,
|
||||||
expires: time.Now().Unix() + (bridgeKeepAlive * 3),
|
expires: time.Now().Unix() + (BridgeKeepAlive * 3),
|
||||||
callerToken: callerToken,
|
callerToken: callerToken,
|
||||||
calleeToken: calleeToken,
|
calleeToken: calleeToken,
|
||||||
}
|
}
|
||||||
@ -53,7 +54,7 @@ func setStatus(bridge Bridge, status string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s BridgeRelay) KeepAlive(bridgeId string) {
|
func (s *BridgeRelay) KeepAlive(callId string) {
|
||||||
s.sync.Lock()
|
s.sync.Lock()
|
||||||
defer s.sync.Unlock()
|
defer s.sync.Unlock()
|
||||||
now := time.Now().Unix()
|
now := time.Now().Unix()
|
||||||
@ -61,8 +62,8 @@ func (s BridgeRelay) KeepAlive(bridgeId string) {
|
|||||||
for _, bridge := range s.bridges {
|
for _, bridge := range s.bridges {
|
||||||
if bridge.expires > now {
|
if bridge.expires > now {
|
||||||
bridges = append(bridges, bridge)
|
bridges = append(bridges, bridge)
|
||||||
if bridge.bridgeId == bridgeId {
|
if bridge.callId == callId {
|
||||||
bridge.expires = now + (bridgeKeepAlive * 3)
|
bridge.expires = now + (BridgeKeepAlive * 3)
|
||||||
if bridge.caller != nil {
|
if bridge.caller != nil {
|
||||||
if err := bridge.caller.WriteMessage(websocket.PingMessage, nil); err != nil {
|
if err := bridge.caller.WriteMessage(websocket.PingMessage, nil); err != nil {
|
||||||
LogMsg("failed to ping caller signal");
|
LogMsg("failed to ping caller signal");
|
||||||
@ -81,12 +82,12 @@ func (s BridgeRelay) KeepAlive(bridgeId string) {
|
|||||||
s.bridges = bridges
|
s.bridges = bridges
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s BridgeRelay) RemoveBridge(bridgeId string) {
|
func (s *BridgeRelay) RemoveBridge(callId string) {
|
||||||
s.sync.Lock()
|
s.sync.Lock()
|
||||||
defer s.sync.Unlock()
|
defer s.sync.Unlock()
|
||||||
var bridges []Bridge
|
var bridges []Bridge
|
||||||
for _, bridge := range s.bridges {
|
for _, bridge := range s.bridges {
|
||||||
if bridge.bridgeId == bridgeId {
|
if bridge.callId == callId {
|
||||||
setStatus(bridge, "closed");
|
setStatus(bridge, "closed");
|
||||||
} else {
|
} else {
|
||||||
bridges = append(bridges, bridge)
|
bridges = append(bridges, bridge)
|
||||||
@ -95,7 +96,7 @@ func (s BridgeRelay) RemoveBridge(bridgeId string) {
|
|||||||
s.bridges = bridges
|
s.bridges = bridges
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s BridgeRelay) SetConnection(conn *websocket.Conn, token string) {
|
func (s *BridgeRelay) SetConnection(conn *websocket.Conn, token string) {
|
||||||
s.sync.Lock()
|
s.sync.Lock()
|
||||||
defer s.sync.Unlock()
|
defer s.sync.Unlock()
|
||||||
for _, bridge := range s.bridges {
|
for _, bridge := range s.bridges {
|
||||||
@ -118,7 +119,7 @@ func (s BridgeRelay) SetConnection(conn *websocket.Conn, token string) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s BridgeRelay) ClearConnection(conn *websocket.Conn) {
|
func (s *BridgeRelay) ClearConnection(conn *websocket.Conn) {
|
||||||
s.sync.Lock()
|
s.sync.Lock()
|
||||||
defer s.sync.Unlock()
|
defer s.sync.Unlock()
|
||||||
for _, bridge := range s.bridges {
|
for _, bridge := range s.bridges {
|
||||||
@ -133,7 +134,7 @@ func (s BridgeRelay) ClearConnection(conn *websocket.Conn) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s BridgeRelay) RelayMessage(conn *websocket.Conn, msg []byte) {
|
func (s *BridgeRelay) RelayMessage(conn *websocket.Conn, msg []byte) {
|
||||||
s.sync.Lock()
|
s.sync.Lock()
|
||||||
defer s.sync.Unlock()
|
defer s.sync.Unlock()
|
||||||
for _, bridge := range s.bridges {
|
for _, bridge := range s.bridges {
|
||||||
@ -149,3 +150,4 @@ func (s BridgeRelay) RelayMessage(conn *websocket.Conn, msg []byte) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user