mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-11 23:13:21 -05:00
Added task limiter on mesh agent binary updates and legacy swarm server.
This commit is contained in:
parent
8f283715ff
commit
659b90e75f
16
meshagent.js
16
meshagent.js
@ -62,7 +62,11 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
|
|
||||||
// Other clean up may be needed here
|
// Other clean up may be needed here
|
||||||
if (obj.unauth) { delete obj.unauth; }
|
if (obj.unauth) { delete obj.unauth; }
|
||||||
if (obj.agentUpdate != null) { obj.fs.close(obj.agentUpdate.fd); obj.agentUpdate = null; }
|
if (obj.agentUpdate != null) {
|
||||||
|
obj.fs.close(obj.agentUpdate.fd);
|
||||||
|
obj.parent.parent.taskLimiter.completed(obj.agentUpdate.taskid); // Indicate this task complete
|
||||||
|
obj.agentUpdate = null;
|
||||||
|
}
|
||||||
if (((obj.agentInfo) && (obj.agentInfo.capabilities) && (obj.agentInfo.capabilities & 0x20)) || ((mesh) && (mesh.flags) && (mesh.flags & 1))) { // This is a temporary agent, remote it
|
if (((obj.agentInfo) && (obj.agentInfo.capabilities) && (obj.agentInfo.capabilities & 0x20)) || ((mesh) && (mesh.flags) && (mesh.flags & 1))) { // This is a temporary agent, remote it
|
||||||
// Delete this node including network interface information and events
|
// Delete this node including network interface information and events
|
||||||
obj.db.Remove(obj.dbNodeKey); // Remove node with that id
|
obj.db.Remove(obj.dbNodeKey); // Remove node with that id
|
||||||
@ -163,11 +167,12 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
if ((msg.length == 52) && (obj.agentExeInfo != null) && (obj.agentExeInfo.update == true)) {
|
if ((msg.length == 52) && (obj.agentExeInfo != null) && (obj.agentExeInfo.update == true)) {
|
||||||
var agenthash = obj.common.rstr2hex(msg.substring(4)).toLowerCase();
|
var agenthash = obj.common.rstr2hex(msg.substring(4)).toLowerCase();
|
||||||
if ((agenthash != obj.agentExeInfo.hash) && (agenthash != '000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000')) {
|
if ((agenthash != obj.agentExeInfo.hash) && (agenthash != '000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000000')) {
|
||||||
// Mesh agent update required
|
// Mesh agent update required, do it using task limiter so not to flood the network.
|
||||||
|
obj.parent.parent.taskLimiter.launch(function (argument, taskid, taskLimiterQueue) {
|
||||||
if (obj.nodeid != null) { obj.parent.parent.debug(1, 'Agent update required, NodeID=0x' + obj.nodeid.substring(0, 16) + ', ' + obj.agentExeInfo.desc); }
|
if (obj.nodeid != null) { obj.parent.parent.debug(1, 'Agent update required, NodeID=0x' + obj.nodeid.substring(0, 16) + ', ' + obj.agentExeInfo.desc); }
|
||||||
obj.fs.open(obj.agentExeInfo.path, 'r', function (err, fd) {
|
obj.fs.open(obj.agentExeInfo.path, 'r', function (err, fd) {
|
||||||
if (err) { return console.error(err); }
|
if (err) { return console.error(err); }
|
||||||
obj.agentUpdate = { oldHash: agenthash, ptr: 0, buf: Buffer.alloc(agentUpdateBlockSize + 4), fd: fd };
|
obj.agentUpdate = { oldHash: agenthash, ptr: 0, buf: Buffer.alloc(agentUpdateBlockSize + 4), fd: fd, taskid: taskid };
|
||||||
|
|
||||||
// MeshCommand_CoreModule, ask mesh agent to clear the core.
|
// MeshCommand_CoreModule, ask mesh agent to clear the core.
|
||||||
// The new core will only be sent after the agent updates.
|
// The new core will only be sent after the agent updates.
|
||||||
@ -187,6 +192,7 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
if (len == -1) {
|
if (len == -1) {
|
||||||
// Error reading the agent file, stop here.
|
// Error reading the agent file, stop here.
|
||||||
obj.fs.close(obj.agentUpdate.fd);
|
obj.fs.close(obj.agentUpdate.fd);
|
||||||
|
obj.parent.parent.taskLimiter.completed(obj.agentUpdate.taskid); // Indicate this task complete
|
||||||
obj.agentUpdate = null;
|
obj.agentUpdate = null;
|
||||||
} else {
|
} else {
|
||||||
// Send the first block to the agent
|
// Send the first block to the agent
|
||||||
@ -195,6 +201,8 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
obj.send(obj.agentUpdate.buf); // Command 14, mesh agent first data block
|
obj.send(obj.agentUpdate.buf); // Command 14, mesh agent first data block
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
}, null);
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
// Check the mesh core, if the agent is capable of running one
|
// Check the mesh core, if the agent is capable of running one
|
||||||
if (((obj.agentInfo.capabilities & 16) != 0) && (obj.parent.parent.meshAgentsArchitectureNumbers[obj.agentInfo.agentId].core != null)) {
|
if (((obj.agentInfo.capabilities & 16) != 0) && (obj.parent.parent.meshAgentsArchitectureNumbers[obj.agentInfo.agentId].core != null)) {
|
||||||
@ -212,6 +220,7 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
if (len == -1) {
|
if (len == -1) {
|
||||||
// Error reading the agent file, stop here.
|
// Error reading the agent file, stop here.
|
||||||
obj.fs.close(obj.agentUpdate.fd);
|
obj.fs.close(obj.agentUpdate.fd);
|
||||||
|
obj.parent.parent.taskLimiter.completed(obj.agentUpdate.taskid); // Indicate this task complete
|
||||||
obj.agentUpdate = null;
|
obj.agentUpdate = null;
|
||||||
} else {
|
} else {
|
||||||
// Send the next block to the agent
|
// Send the next block to the agent
|
||||||
@ -223,6 +232,7 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
//console.log("Agent update sent");
|
//console.log("Agent update sent");
|
||||||
obj.send(obj.common.ShortToStr(13) + obj.common.ShortToStr(0) + obj.common.hex2rstr(obj.agentExeInfo.hash)); // Command 13, end mesh agent download, send agent SHA384 hash
|
obj.send(obj.common.ShortToStr(13) + obj.common.ShortToStr(0) + obj.common.hex2rstr(obj.agentExeInfo.hash)); // Command 13, end mesh agent download, send agent SHA384 hash
|
||||||
obj.fs.close(obj.agentUpdate.fd);
|
obj.fs.close(obj.agentUpdate.fd);
|
||||||
|
obj.parent.parent.taskLimiter.completed(obj.agentUpdate.taskid); // Indicate this task complete
|
||||||
obj.agentUpdate = null;
|
obj.agentUpdate = null;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -214,7 +214,12 @@ module.exports.CreateSwarmServer = function (parent, db, args, certificates) {
|
|||||||
socket.tag.update = obj.migrationAgents[nodeblock.agenttype][nextAgentVersion];
|
socket.tag.update = obj.migrationAgents[nodeblock.agenttype][nextAgentVersion];
|
||||||
socket.tag.updatePtr = 0;
|
socket.tag.updatePtr = 0;
|
||||||
//console.log('Performing legacy agent update from ' + nodeblock.agentversion + '.' + nodeblock.agenttype + ' to ' + socket.tag.update.ver + '.' + socket.tag.update.arch + ' on ' + nodeblock.agentname + '.');
|
//console.log('Performing legacy agent update from ' + nodeblock.agentversion + '.' + nodeblock.agenttype + ' to ' + socket.tag.update.ver + '.' + socket.tag.update.arch + ' on ' + nodeblock.agentname + '.');
|
||||||
|
|
||||||
|
// Start the agent download using the task limiter so not to flood the server.
|
||||||
|
obj.parent.taskLimiter.launch(function (socket, taskid, taskLimiterQueue) {
|
||||||
|
socket.tag.taskid = taskid;
|
||||||
obj.SendCommand(socket, LegacyMeshProtocol.GETSTATE, common.IntToStr(5) + common.IntToStr(0)); // agent.SendQuery(5, 0); // Start the agent download
|
obj.SendCommand(socket, LegacyMeshProtocol.GETSTATE, common.IntToStr(5) + common.IntToStr(0)); // agent.SendQuery(5, 0); // Start the agent download
|
||||||
|
}, socket);
|
||||||
} else {
|
} else {
|
||||||
//console.log('No legacy agent update for ' + nodeblock.agentversion + '.' + nodeblock.agenttype + ' on ' + nodeblock.agentname + '.');
|
//console.log('No legacy agent update for ' + nodeblock.agentversion + '.' + nodeblock.agenttype + ' on ' + nodeblock.agentname + '.');
|
||||||
}
|
}
|
||||||
@ -248,6 +253,8 @@ module.exports.CreateSwarmServer = function (parent, db, args, certificates) {
|
|||||||
// Send end-of-transfer
|
// Send end-of-transfer
|
||||||
obj.SendCommand(socket, LegacyMeshProtocol.GETSTATE, common.IntToStr(7) + common.IntToStr(socket.tag.update.binary.length)); //agent.SendQuery(7, AgentFileLen);
|
obj.SendCommand(socket, LegacyMeshProtocol.GETSTATE, common.IntToStr(7) + common.IntToStr(socket.tag.update.binary.length)); //agent.SendQuery(7, AgentFileLen);
|
||||||
Debug(3, 'Swarm:Sending end of agent, ptr = ' + socket.tag.updatePtr);
|
Debug(3, 'Swarm:Sending end of agent, ptr = ' + socket.tag.updatePtr);
|
||||||
|
obj.parent.taskLimiter.completed(socket.tag.taskid); // Indicate this task complete
|
||||||
|
delete socket.tag.taskid;
|
||||||
delete socket.tag.update;
|
delete socket.tag.update;
|
||||||
delete socket.tag.updatePtr;
|
delete socket.tag.updatePtr;
|
||||||
}
|
}
|
||||||
@ -274,9 +281,11 @@ module.exports.CreateSwarmServer = function (parent, db, args, certificates) {
|
|||||||
|
|
||||||
socket.addListener("close", function () {
|
socket.addListener("close", function () {
|
||||||
Debug(1, 'Swarm:Connection closed');
|
Debug(1, 'Swarm:Connection closed');
|
||||||
try { delete obj.ciraConnections[socket.tag.nodeid]; } catch (e) { }
|
|
||||||
obj.parent.ClearConnectivityState(socket.tag.meshid, socket.tag.nodeid, 2);
|
|
||||||
if (socket.pingTimer != null) { clearInterval(socket.pingTimer); delete socket.pingTimer; }
|
if (socket.pingTimer != null) { clearInterval(socket.pingTimer); delete socket.pingTimer; }
|
||||||
|
if (socket.tag && (typeof socket.tag.taskid == 'number')) {
|
||||||
|
obj.parent.taskLimiter.completed(socket.tag.taskid); // Indicate this task complete
|
||||||
|
delete socket.tag.taskid;
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
socket.addListener("error", function () {
|
socket.addListener("error", function () {
|
||||||
@ -344,8 +353,6 @@ module.exports.CreateSwarmServer = function (parent, db, args, certificates) {
|
|||||||
// Disconnect legacy agent connection
|
// Disconnect legacy agent connection
|
||||||
obj.close = function (socket) {
|
obj.close = function (socket) {
|
||||||
try { socket.close(); } catch (e) { }
|
try { socket.close(); } catch (e) { }
|
||||||
try { delete obj.ciraConnections[socket.tag.nodeid]; } catch (e) { }
|
|
||||||
obj.parent.ClearConnectivityState(socket.tag.meshid, socket.tag.nodeid, 2);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
obj.SendCommand = function (socket, cmdid, data) {
|
obj.SendCommand = function (socket, cmdid, data) {
|
||||||
|
Loading…
Reference in New Issue
Block a user