feat: 'new websocket' to share whiteboard info

* share whiteboard info only on change and at specific frequency
* front update to track nb user connected
This commit is contained in:
Florent Chehab 2020-05-10 15:34:19 +02:00
parent 6475fdd5db
commit 685caffd43
No known key found for this signature in database
GPG Key ID: 9A0CE018889EA246
6 changed files with 109 additions and 4 deletions

View File

@ -0,0 +1,45 @@
class WhiteboardServerSideInfo {
constructor() {
/**
* @type {number}
* @private
*/
this._nbConnectedUsers = 0;
/**
* Variable to tell if these info have been sent or not
*
* @private
* @type {boolean}
*/
this._hasNonSentUpdates = false;
}
incrementNbConnectedUsers() {
this._nbConnectedUsers++;
this._hasNonSentUpdates = true;
}
decrementNbConnectedUsers() {
this._nbConnectedUsers--;
this._hasNonSentUpdates = true;
}
hasConnectedUser() {
return this._nbConnectedUsers > 0;
}
asObject() {
return { nbConnectedUsers: this._nbConnectedUsers };
}
infoWasSent() {
this._hasNonSentUpdates = false;
}
shouldSendInfo() {
return this._hasNonSentUpdates;
}
}
module.exports = WhiteboardServerSideInfo;

5
scripts/config.js Normal file
View File

@ -0,0 +1,5 @@
const config = {
whiteboardInfoBroadcastFreq: 1, // once per second
};
module.exports = config;

View File

@ -1,6 +1,9 @@
const { getArgs } = require("./utils");
const path = require("path"); const path = require("path");
const { getArgs } = require("./utils");
const config = require("./config");
const WhiteboardServerSideInfo = require("./WhiteboardServerSideInfo");
function startBackendServer(port) { function startBackendServer(port) {
var accessToken = ""; //Can be set here or as start parameter (node server.js --accesstoken=MYTOKEN) var accessToken = ""; //Can be set here or as start parameter (node server.js --accesstoken=MYTOKEN)
var disableSmallestScreen = false; //Can be set to true if you dont want to show (node server.js --disablesmallestscreen=true) var disableSmallestScreen = false; //Can be set to true if you dont want to show (node server.js --disablesmallestscreen=true)
@ -205,9 +208,26 @@ function startBackendServer(port) {
} }
var smallestScreenResolutions = {}; var smallestScreenResolutions = {};
/**
* @type {Map<string, WhiteboardServerSideInfo>}
*/
const infoByWhiteboard = new Map();
setInterval(() => {
infoByWhiteboard.forEach((info, whiteboardId) => {
if (info.shouldSendInfo()) {
io.sockets
.in(whiteboardId)
.compress(false)
.emit("whiteboardInfoUpdate", info.asObject());
info.infoWasSent();
}
});
}, (1 / config.whiteboardInfoBroadcastFreq) * 1000);
io.on("connection", function (socket) { io.on("connection", function (socket) {
var whiteboardId = null; var whiteboardId = null;
socket.on("disconnect", function () { socket.on("disconnect", function () {
if ( if (
smallestScreenResolutions && smallestScreenResolutions &&
@ -217,8 +237,15 @@ function startBackendServer(port) {
) { ) {
delete smallestScreenResolutions[whiteboardId][socket.id]; delete smallestScreenResolutions[whiteboardId][socket.id];
} }
const whiteboardServerSideInfo = infoByWhiteboard.get(whiteboardId);
whiteboardServerSideInfo.decrementNbConnectedUsers();
if (whiteboardServerSideInfo.hasConnectedUser()) {
socket.compress(false).broadcast.emit("refreshUserBadges", null); //Removes old user Badges socket.compress(false).broadcast.emit("refreshUserBadges", null); //Removes old user Badges
sendSmallestScreenResolution(); sendSmallestScreenResolution();
} else {
infoByWhiteboard.delete(whiteboardId);
}
}); });
socket.on("drawToWhiteboard", function (content) { socket.on("drawToWhiteboard", function (content) {
@ -236,6 +263,13 @@ function startBackendServer(port) {
if (accessToken === "" || accessToken == content["at"]) { if (accessToken === "" || accessToken == content["at"]) {
whiteboardId = content["wid"]; whiteboardId = content["wid"];
socket.join(whiteboardId); //Joins room name=wid socket.join(whiteboardId); //Joins room name=wid
if (!infoByWhiteboard.has(whiteboardId)) {
infoByWhiteboard.set(whiteboardId, new WhiteboardServerSideInfo());
}
const whiteboardServerSideInfo = infoByWhiteboard.get(whiteboardId);
whiteboardServerSideInfo.incrementNbConnectedUsers();
smallestScreenResolutions[whiteboardId] = smallestScreenResolutions[whiteboardId] smallestScreenResolutions[whiteboardId] = smallestScreenResolutions[whiteboardId]
? smallestScreenResolutions[whiteboardId] ? smallestScreenResolutions[whiteboardId]
: {}; : {};

View File

@ -253,6 +253,7 @@
<div id="whiteboardInfoContainer"> <div id="whiteboardInfoContainer">
<p><b>Whiteboard information:</b></p> <p><b>Whiteboard information:</b></p>
<p># connected users: <i id="connectedUsersCount">0</i></p>
<p># msg. sent to server: <i id="messageSentCount">0</i></p> <p># msg. sent to server: <i id="messageSentCount">0</i></p>
<p># msg. received from server: <i id="messageReceivedCount">0</i></p> <p># msg. received from server: <i id="messageReceivedCount">0</i></p>
</div> </div>

View File

@ -49,6 +49,10 @@ function main() {
signaling_socket.on("connect", function () { signaling_socket.on("connect", function () {
console.log("Websocket connected!"); console.log("Websocket connected!");
signaling_socket.on("whiteboardInfoUpdate", (info) => {
InfoService.updateInfoFromServer(info);
});
signaling_socket.on("drawToWhiteboard", function (content) { signaling_socket.on("drawToWhiteboard", function (content) {
whiteboard.handleEventsAndData(content, true); whiteboard.handleEventsAndData(content, true);
InfoService.incrementNbMessagesReceived(); InfoService.incrementNbMessagesReceived();

View File

@ -12,6 +12,14 @@ class InfoService {
*/ */
_infoAreDisplayed = false; _infoAreDisplayed = false;
/**
* Holds the number of user connected to the server
*
* @type {number}
* @private
*/
_nbConnectedUsers = 0;
/** /**
* @type {number} * @type {number}
* @private * @private
@ -31,6 +39,13 @@ class InfoService {
*/ */
_refreshInfoIntervalId = undefined; _refreshInfoIntervalId = undefined;
/**
* @param {number} nbConnectedUsers
*/
updateInfoFromServer({ nbConnectedUsers }) {
this._nbConnectedUsers = nbConnectedUsers;
}
incrementNbMessagesReceived() { incrementNbMessagesReceived() {
this._nbMessagesReceived++; this._nbMessagesReceived++;
} }
@ -42,6 +57,7 @@ class InfoService {
refreshDisplayedInfo() { refreshDisplayedInfo() {
$("#messageReceivedCount")[0].innerText = String(this._nbMessagesReceived); $("#messageReceivedCount")[0].innerText = String(this._nbMessagesReceived);
$("#messageSentCount")[0].innerText = String(this._nbMessagesSent); $("#messageSentCount")[0].innerText = String(this._nbMessagesSent);
$("#connectedUsersCount")[0].innerText = String(this._nbConnectedUsers);
} }
displayInfo() { displayInfo() {