From 78cc620dcb34e5165d4bf451cfdca73c9e01b383 Mon Sep 17 00:00:00 2001 From: Ylian Saint-Hilaire Date: Mon, 11 Mar 2019 17:33:24 -0700 Subject: [PATCH] Fixed SSPI session release bug. --- meshuser.js | 18 +++++++++--------- package.json | 2 +- swarmserver.js | 4 +--- 3 files changed, 11 insertions(+), 13 deletions(-) diff --git a/meshuser.js b/meshuser.js index a5ff865b..bb29d847 100644 --- a/meshuser.js +++ b/meshuser.js @@ -36,19 +36,19 @@ module.exports.CreateMeshUser = function (parent, db, ws, req, args, domain, use if (obj.serverStatsTimer != null) { clearInterval(obj.serverStatsTimer); delete obj.serverStatsTimer; } if (req.session && req.session.ws && req.session.ws == ws) { delete req.session.ws; } if (parent.wssessions2[ws.sessionId]) { delete parent.wssessions2[ws.sessionId]; } - if (parent.wssessions[ws.userid]) { - var i = parent.wssessions[ws.userid].indexOf(ws); + if (parent.wssessions[obj.user._id]) { + var i = parent.wssessions[obj.user._id].indexOf(ws); if (i >= 0) { - parent.wssessions[ws.userid].splice(i, 1); - var user = parent.users[ws.userid]; + parent.wssessions[obj.user._id].splice(i, 1); + var user = parent.users[obj.user._id]; if (user) { if (parent.parent.multiServer == null) { - parent.parent.DispatchEvent(['*'], obj, { action: 'wssessioncount', username: user.name, count: parent.wssessions[ws.userid].length, nolog: 1, domain: domain.id }); + parent.parent.DispatchEvent(['*'], obj, { action: 'wssessioncount', username: obj.user.name, count: parent.wssessions[obj.user._id].length, nolog: 1, domain: domain.id }); } else { parent.recountSessions(ws.sessionId); // Recount sessions } } - if (parent.wssessions[ws.userid].length == 0) { delete parent.wssessions[ws.userid]; } + if (parent.wssessions[obj.user._id].length == 0) { delete parent.wssessions[obj.user._id]; } } } @@ -166,7 +166,7 @@ module.exports.CreateMeshUser = function (parent, db, ws, req, args, domain, use } // Associate this websocket session with the web session - ws.userid = req.session.userid; + ws.userid = user._id; ws.domainid = domain.id; // Create a new session id for this user. @@ -1281,8 +1281,8 @@ module.exports.CreateMeshUser = function (parent, db, ws, req, args, domain, use // Ask the RMCP scanning to scan a range of IP addresses if (parent.parent.amtScanner) { - if (parent.parent.amtScanner.performRangeScan(ws.userid, command.range) == false) { - parent.parent.DispatchEvent(['*', ws.userid], obj, { action: 'scanamtdevice', range: command.range, results: null, nolog: 1 }); + if (parent.parent.amtScanner.performRangeScan(user._id, command.range) == false) { + parent.parent.DispatchEvent(['*', user._id], obj, { action: 'scanamtdevice', range: command.range, results: null, nolog: 1 }); } } break; diff --git a/package.json b/package.json index a55a6a80..ae4fef7a 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "meshcentral", - "version": "0.3.0-h", + "version": "0.3.0-i", "keywords": [ "Remote Management", "Intel AMT", diff --git a/swarmserver.js b/swarmserver.js index d55d943e..91a6c63c 100644 --- a/swarmserver.js +++ b/swarmserver.js @@ -392,9 +392,7 @@ module.exports.CreateSwarmServer = function (parent, db, args, certificates) { ptr += blen; } return info; - } catch (e) { - console.log(e); - } + } catch (e) { } return null; };