mirror of
https://gitlab.com/comunic/comunicapiv2
synced 2024-11-22 13:29:22 +00:00
Forward signals for web app to rtc proxy
This commit is contained in:
parent
18dbc6fd9f
commit
2e6461c34a
@ -5,6 +5,7 @@ import { EventsHelper } from "../helpers/EventsHelper";
|
|||||||
import * as ws from 'ws'
|
import * as ws from 'ws'
|
||||||
import { WsMessage } from "../entities/WsMessage";
|
import { WsMessage } from "../entities/WsMessage";
|
||||||
import { conf } from "../helpers/ConfigHelper";
|
import { conf } from "../helpers/ConfigHelper";
|
||||||
|
import { RTCRelayController } from "./RTCRelayController";
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Legacy calls controller
|
* Legacy calls controller
|
||||||
@ -104,6 +105,39 @@ export class CallsController {
|
|||||||
).map(f => f.userID))
|
).map(f => f.userID))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Handles client signal
|
||||||
|
*
|
||||||
|
* @param h Request handler
|
||||||
|
*/
|
||||||
|
public static async OnClientSignal(h: UserWebSocketRequestsHandler) {
|
||||||
|
const callID = h.postCallId("callID");
|
||||||
|
const peerID = h.postCallPeerID(callID, "peerID");
|
||||||
|
const type = h.postString("type");
|
||||||
|
const data = h.postJSON("data");
|
||||||
|
|
||||||
|
if(type !== "SDP" && type !== "CANDIDATE")
|
||||||
|
h.error(401, "Invalid candidate type");
|
||||||
|
|
||||||
|
if(type == "SDP" && (!data.hasOwnProperty("type") || data.type !== "offer" || !data.hasOwnProperty("sdp")))
|
||||||
|
h.error(401, "Invalid SDP signal!")
|
||||||
|
|
||||||
|
if(type == "CANDIDATE" && (!data.hasOwnProperty("candidate") || !data.hasOwnProperty("sdpMLineIndex") || !data.hasOwnProperty("sdpMid")))
|
||||||
|
h.error(401, "Invalid candidate signal!")
|
||||||
|
|
||||||
|
await RTCRelayController.SendMessage({
|
||||||
|
title: "signal",
|
||||||
|
callHash: callID+"-"+peerID,
|
||||||
|
peerId: String(peerID === h.getUserId() ? 0 : peerID),
|
||||||
|
data: {
|
||||||
|
type: type,
|
||||||
|
data: data
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
h.success()
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Make the client leave the call
|
* Make the client leave the call
|
||||||
*
|
*
|
||||||
|
@ -102,7 +102,7 @@ export class RTCRelayController {
|
|||||||
* @param title The title of the message to send
|
* @param title The title of the message to send
|
||||||
* @param content The content of the message
|
* @param content The content of the message
|
||||||
*/
|
*/
|
||||||
private static async SendMessage(msg: RTCSocketMessage) {
|
public static async SendMessage(msg: RTCSocketMessage) {
|
||||||
this.currWs.send(JSON.stringify({
|
this.currWs.send(JSON.stringify({
|
||||||
title: msg.title,
|
title: msg.title,
|
||||||
callHash: msg.callHash,
|
callHash: msg.callHash,
|
||||||
|
@ -40,4 +40,6 @@ export const UserWebSocketRoutes: UserWebSocketRoute[] = [
|
|||||||
{title: "calls/leave", handler: (h) => CallsController.LeaveCall(h)},
|
{title: "calls/leave", handler: (h) => CallsController.LeaveCall(h)},
|
||||||
|
|
||||||
{title: "calls/members", handler: (h) => CallsController.GetMembersList(h)},
|
{title: "calls/members", handler: (h) => CallsController.GetMembersList(h)},
|
||||||
|
|
||||||
|
{title: "calls/signal", handler: (h) => CallsController.OnClientSignal(h)},
|
||||||
]
|
]
|
@ -80,4 +80,20 @@ export class UserWebSocketRequestsHandler extends BaseRequestsHandler {
|
|||||||
|
|
||||||
return convID;
|
return convID;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get the ID of a peer of a call included in the WebSocket request
|
||||||
|
*
|
||||||
|
* @param callID Target call ID
|
||||||
|
* @param name The name of the POST field
|
||||||
|
*/
|
||||||
|
public postCallPeerID(callID: number, name: string) : number{
|
||||||
|
const peerID = this.postInt(name);
|
||||||
|
|
||||||
|
if(peerID != this.getUserId() && UserWebSocketController.active_clients.find(
|
||||||
|
(e) => e.userID == peerID && e.activeCalls.has(callID)) === undefined)
|
||||||
|
this.error(401, "This peer is not a member of the call!");
|
||||||
|
|
||||||
|
return peerID;
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user