First working p2p videochat.

I've integrated a simple react express backend with a Peerjs server.
It can be published under a simple "ngrok.io" tunnel for testing on
internet.
This commit is contained in:
2020-12-29 14:42:38 +01:00
commit 132fb3a3c1
6 changed files with 1703 additions and 0 deletions

41
games-party/server.js Normal file
View File

@@ -0,0 +1,41 @@
const express = require('express')
const app = express()
const server = require('http').Server(app)
const io = require('socket.io')(server)
const { v4: uuidV4 } = require('uuid')
const { ExpressPeerServer } = require('peer');
app.enable('trust proxy');
app.set('view engine', 'ejs')
app.use(express.static('public'))
app.get('/', (request, response) => {
// create a room
// redirect to a room
response.redirect(`/r/${uuidV4()}`)
})
app.get('/r/:room', (request, response) => {
response.render('room', { roomId: request.params.room })
})
io.on('connection', socket => {
socket.on('join-room', (roomId, userId) => {
socket.join(roomId)
socket.to(roomId).broadcast.emit('user-connected', userId)
socket.on('disconnect', () => {
socket.to(roomId).broadcast.emit('user-disconnected', userId)
})
})
})
// Connection broker
const peerServer = ExpressPeerServer(server, {
debug: true,
path: '/domingo'
})
app.use('/peerjs', peerServer)
server.listen(3000, '0.0.0.0')