mirror of
https://github.com/MercuryWorkshop/adrift.git
synced 2025-05-13 14:20:01 -04:00
90 lines
2.2 KiB
TypeScript
90 lines
2.2 KiB
TypeScript
import dotenv from "dotenv";
|
|
import express from "express";
|
|
import * as wrtc from "wrtc";
|
|
|
|
const configuration = {
|
|
iceServers: [
|
|
{
|
|
urls: "stun:stun.l.google.com:19302",
|
|
},
|
|
],
|
|
};
|
|
dotenv.config();
|
|
|
|
async function connect(
|
|
offer,
|
|
candidates,
|
|
onAnswer: (answer: Record<string, any>) => void
|
|
) {
|
|
const localCandidates: any[] = [];
|
|
let dataChannel;
|
|
const peer = new wrtc.RTCPeerConnection(configuration);
|
|
peer.ondatachannel = (event) => {
|
|
dataChannel = event.channel;
|
|
dataChannel.onopen = () => {
|
|
console.log("opened");
|
|
};
|
|
dataChannel.onclose = (event) => {
|
|
console.log("closed");
|
|
};
|
|
dataChannel.onmessage = (event) => {
|
|
console.log("messaged");
|
|
console.log(event);
|
|
};
|
|
};
|
|
peer.onconnectionstatechange = () => {
|
|
console.log("Connection state:", peer.connectionState);
|
|
};
|
|
peer.onsignalingstatechange = () => {
|
|
console.log("Signaling state:", peer.signalingState);
|
|
};
|
|
peer.oniceconnectionstatechange = () => {
|
|
console.log("ICE connection state:", peer.iceConnectionState);
|
|
};
|
|
peer.onicegatheringstatechange = () => {
|
|
console.log("ICE gathering state:", peer.iceGatheringState);
|
|
};
|
|
peer.onicecandidate = (event: any) => {
|
|
console.log("onicecandidate");
|
|
if (event.candidate) {
|
|
localCandidates.push(event.candidate);
|
|
return;
|
|
}
|
|
let payload = {
|
|
answer: peer.localDescription,
|
|
candidates: localCandidates,
|
|
};
|
|
onAnswer(payload);
|
|
};
|
|
await peer.setRemoteDescription(offer);
|
|
let answer = await peer.createAnswer();
|
|
await peer.setLocalDescription(answer);
|
|
for (let candidate of candidates) {
|
|
if (!candidate.candidate) continue;
|
|
console.log({ candidate });
|
|
await peer.addIceCandidate(candidate);
|
|
}
|
|
}
|
|
|
|
const app = express();
|
|
app.use(express.json());
|
|
app.use((req, res, next) => {
|
|
res.header("Access-Control-Allow-Origin", "*");
|
|
next();
|
|
});
|
|
|
|
app.post("/connect", (req, res) => {
|
|
const data = req.body;
|
|
if (data && data.offer && data.localCandidates) {
|
|
const { offer, localCandidates } = data;
|
|
let didAnswer = false;
|
|
connect(offer, localCandidates, (answer) => {
|
|
if (!didAnswer) {
|
|
didAnswer = true;
|
|
res.json(answer);
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
app.listen(3000, () => console.log("listening"));
|