X-Git-Url: https://git.r.bdr.sh/rbdr/junction/blobdiff_plain/284fc661dc7f18aa32d0dbcd8e7f98cb16af4bb7..6717f3d8b71abf255b0e07a5024caa602b5a3d3c:/server/index.js diff --git a/server/index.js b/server/index.js index e6a37c7..e60795f 100644 --- a/server/index.js +++ b/server/index.js @@ -1,66 +1,56 @@ -import { Server } from 'socket.io'; -import { port } from './config.js'; -import * as events from './events.js'; +import { Server } from "socket.io"; +import { port } from "./config.js"; +import * as events from "./events.js"; const server = new Server(port); -console.log(`Listening on port ${port}`); +console.debug(`Listening on port ${port}`); const rooms = {}; -server.on('connection', (socket) => { - const me = socket.id; +server.on(events.types.CONNECTION, (socket) => { + const me = socket.id; - console.log(`[CONNECT] New client connected with ID ${me}`); + console.debug(`[CONNECT] New client connected with ID ${me}`); - socket.on('join', async (data) => { - const room = data.room; - socket.join(room); + socket.on(events.types.JOIN, async ({ room }) => { + socket.join(room); - if (!rooms[room]) { - rooms[room] = {}; - } + if (!rooms[room]) { + rooms[room] = []; + } - rooms[room].push(socket.id); + rooms[room].push(socket.id); - const sockets = await server.in(data.url).fetchSockets() - sockets.forEach((peer) => { - if (peer.id !== me) { - peer.emit(events.types.ADD_PEER, events.addPeer(me, false)); - socket.emit(events.types.ADD_PEER, events.addPeer(peer.id, true)); - } - }); - console.log(`[CONNECT] Client ${me} added to room ${data.url}`); + const sockets = await server.in(room).fetchSockets(); + sockets.forEach((peer) => { + if (peer.id !== me) { + events.addPeer(me, false)(peer); + events.addPeer(peer.id, true)(socket); + } }); - - socket.on('disconnecting', () => { - - for (const room in rooms) { - if (rooms[room].includes(me)) { - rooms[room] = rooms[room].filter(id => id !== me); - socket.to(room).emit(events.types.REMOVE_PEER, events.removePeer(me)); - if (rooms[room].length === 0) { - delete rooms[room]; - } + }); + + socket.on(events.types.DISCONNECTING, () => { + for (const room in rooms) { + if (rooms[room].includes(me)) { + rooms[room] = rooms[room].filter((id) => id !== me); + events.removePeer(me)(socket.to(room)); + if (rooms[room].length === 0) { + delete rooms[room]; } } - console.log(`[DISCONNECT] Client ${me} has disconnected and has been removed from all rooms`); - }); + } + }); - socket.on('relayICECandidate', async (data) => { + socket.on(events.types.RELAY_ICE_CANDIDATE, async ({ candidate, peerId }) => { + events.ICECandidateReceived(me, candidate)(socket.to(peerId)); + }); - socket.to(data.peerId).emit(events.types.ICE_CANDIDATE_RECEIVED, events.ICECandidateReceived(me, data.candidate)) - console.log(`[RELAY_ICE_CANDIDATE] ICE candidate for client ${me} has been relayed to all peers`); - }); - - socket.on('relayOffer', async (data) => { - - socket.to(data.peerId).emit(events.types.OFFER_RECEIVED, events.offerReceived(me, data.offer)) - console.log(`[RELAY_OFFER] ICE offer for client ${me} has been relayed to all peers`); - }); - - socket.on('relayAnswer', async (data) => { + socket.on(events.types.RELAY_OFFER, async ({ offer, peerId }) => { + events.offerReceived(me, offer)(socket.to(peerId)); + }); - socket.to(data.peerId).emit(events.types.ANSWER_RECEIVED, events.answerReceived(me, data.answer)) - console.log(`[RELAY_OFFER] ICE offer for client ${me} has been relayed to all peers`); - }); + socket.on(events.types.RELAY_ANSWER, async ({ answer, peerId }) => { + events.answerReceived(me, answer)(socket.to(peerId)); + }); });