mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-25 21:53:14 -05:00
Added support fo domain MaxDevices limit
This commit is contained in:
parent
2d86b614d6
commit
73ca2c5780
4
db.js
4
db.js
@ -549,7 +549,7 @@ module.exports.CreateDB = function (parent, func) {
|
|||||||
// TODO: Starting in MongoDB 4.0.3, you should use countDocuments() instead of count() that is deprecated. We should detect MongoDB version and switch.
|
// TODO: Starting in MongoDB 4.0.3, you should use countDocuments() instead of count() that is deprecated. We should detect MongoDB version and switch.
|
||||||
// https://docs.mongodb.com/manual/reference/method/db.collection.countDocuments/
|
// https://docs.mongodb.com/manual/reference/method/db.collection.countDocuments/
|
||||||
//obj.isMaxType = function (max, type, domainid, func) { if (max == null) { func(false); } else { obj.file.countDocuments({ type: type, domain: domainid }, function (err, count) { func((err != null) || (count > max)); }); } }
|
//obj.isMaxType = function (max, type, domainid, func) { if (max == null) { func(false); } else { obj.file.countDocuments({ type: type, domain: domainid }, function (err, count) { func((err != null) || (count > max)); }); } }
|
||||||
obj.isMaxType = function (max, type, domainid, func) { if (max == null) { func(false); } else { obj.file.count({ type: type, domain: domainid }, function (err, count) { func((err != null) || (count > max)); }); } }
|
obj.isMaxType = function (max, type, domainid, func) { if (max == null) { func(false); } else { obj.file.count({ type: type, domain: domainid }, function (err, count) { func((err != null) || (count > max), count); }); } }
|
||||||
|
|
||||||
// Database actions on the events collection
|
// Database actions on the events collection
|
||||||
obj.GetAllEvents = function (func) { obj.eventsfile.find({}).toArray(func); };
|
obj.GetAllEvents = function (func) { obj.eventsfile.find({}).toArray(func); };
|
||||||
@ -638,7 +638,7 @@ module.exports.CreateDB = function (parent, func) {
|
|||||||
obj.dispose = function () { for (var x in obj) { if (obj[x].close) { obj[x].close(); } delete obj[x]; } };
|
obj.dispose = function () { for (var x in obj) { if (obj[x].close) { obj[x].close(); } delete obj[x]; } };
|
||||||
obj.getLocalAmtNodes = function (func) { obj.file.find({ type: 'node', host: { $exists: true, $ne: null }, intelamt: { $exists: true } }, func); };
|
obj.getLocalAmtNodes = function (func) { obj.file.find({ type: 'node', host: { $exists: true, $ne: null }, intelamt: { $exists: true } }, func); };
|
||||||
obj.getAmtUuidNode = function (meshid, uuid, func) { obj.file.find({ type: 'node', meshid: meshid, 'intelamt.uuid': uuid }, func); };
|
obj.getAmtUuidNode = function (meshid, uuid, func) { obj.file.find({ type: 'node', meshid: meshid, 'intelamt.uuid': uuid }, func); };
|
||||||
obj.isMaxType = function (max, type, domainid, func) { if (max == null) { func(false); } else { obj.file.count({ type: type, domain: domainid }, function (err, count) { func((err != null) || (count > max)); }); } }
|
obj.isMaxType = function (max, type, domainid, func) { if (max == null) { func(false); } else { obj.file.count({ type: type, domain: domainid }, function (err, count) { func((err != null) || (count > max), count); }); } }
|
||||||
|
|
||||||
// Database actions on the events collection
|
// Database actions on the events collection
|
||||||
obj.GetAllEvents = function (func) { obj.eventsfile.find({}, func); };
|
obj.GetAllEvents = function (func) { obj.eventsfile.find({}, func); };
|
||||||
|
90
meshagent.js
90
meshagent.js
@ -616,40 +616,21 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
if ((nodes == null) || (nodes.length == 0)) {
|
if ((nodes == null) || (nodes.length == 0)) {
|
||||||
// This device does not exist, use the meshid given by the device
|
// This device does not exist, use the meshid given by the device
|
||||||
|
|
||||||
// See if this mesh exists, if it does not we may want to create it.
|
// Check if we already have too many devices for this domain
|
||||||
mesh = getMeshAutoCreate();
|
if (domain.limits && (typeof domain.limits.maxdevices == 'number')) {
|
||||||
|
db.isMaxType(domain.limits.maxdevices, 'node', domain.id, function (ismax, count) {
|
||||||
// Check if the mesh exists
|
if (ismax == true) {
|
||||||
if (mesh == null) {
|
// Too many devices in this domain.
|
||||||
// If we disconnect, the agent will just reconnect. We need to log this or tell agent to connect in a few hours.
|
parent.agentStats.maxDomainDevicesReached++;
|
||||||
parent.agentStats.invalidDomainMeshCount++;
|
|
||||||
console.log('Agent connected with invalid domain/mesh, holding connection (' + obj.remoteaddrport + ', ' + obj.dbMeshKey + ').');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Check if the mesh is the right type
|
|
||||||
if (mesh.mtype != 2) {
|
|
||||||
// If we disconnect, the agent will just reconnect. We need to log this or tell agent to connect in a few hours.
|
|
||||||
parent.agentStats.invalidMeshTypeCount++;
|
|
||||||
console.log('Agent connected with invalid mesh type, holding connection (' + obj.remoteaddrport + ').');
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Mark when this device connected
|
|
||||||
obj.connectTime = Date.now();
|
|
||||||
db.Set({ _id: 'lc' + obj.dbNodeKey, type: 'lastconnect', domain: domain.id, time: obj.connectTime, addr: obj.remoteaddrport });
|
|
||||||
|
|
||||||
// This node does not exist, create it.
|
|
||||||
device = { type: 'node', mtype: mesh.mtype, _id: obj.dbNodeKey, icon: obj.agentInfo.platformType, meshid: obj.dbMeshKey, name: obj.agentInfo.computerName, rname: obj.agentInfo.computerName, domain: domain.id, agent: { ver: obj.agentInfo.agentVersion, id: obj.agentInfo.agentId, caps: obj.agentInfo.capabilities }, host: null };
|
|
||||||
db.Set(device);
|
|
||||||
|
|
||||||
// Event the new node
|
|
||||||
if (obj.agentInfo.capabilities & 0x20) {
|
|
||||||
// This is a temporary agent, don't log.
|
|
||||||
parent.parent.DispatchEvent(['*', obj.dbMeshKey], obj, { etype: 'node', action: 'addnode', node: device, domain: domain.id, nolog: 1 });
|
|
||||||
} else {
|
} else {
|
||||||
parent.parent.DispatchEvent(['*', obj.dbMeshKey], obj, { etype: 'node', action: 'addnode', node: device, msg: ('Added device ' + obj.agentInfo.computerName + ' to mesh ' + mesh.name), domain: domain.id });
|
// We are under the limit, create the new device.
|
||||||
|
completeAgentConnection2();
|
||||||
}
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
completeAgentConnection2();
|
||||||
|
}
|
||||||
|
return;
|
||||||
} else {
|
} else {
|
||||||
device = nodes[0];
|
device = nodes[0];
|
||||||
|
|
||||||
@ -715,6 +696,50 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
completeAgentConnection3();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
function completeAgentConnection2(device) {
|
||||||
|
// See if this mesh exists, if it does not we may want to create it.
|
||||||
|
var mesh = getMeshAutoCreate();
|
||||||
|
|
||||||
|
// Check if the mesh exists
|
||||||
|
if (mesh == null) {
|
||||||
|
// If we disconnect, the agent will just reconnect. We need to log this or tell agent to connect in a few hours.
|
||||||
|
parent.agentStats.invalidDomainMeshCount++;
|
||||||
|
console.log('Agent connected with invalid domain/mesh, holding connection (' + obj.remoteaddrport + ', ' + obj.dbMeshKey + ').');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check if the mesh is the right type
|
||||||
|
if (mesh.mtype != 2) {
|
||||||
|
// If we disconnect, the agent will just reconnect. We need to log this or tell agent to connect in a few hours.
|
||||||
|
parent.agentStats.invalidMeshTypeCount++;
|
||||||
|
console.log('Agent connected with invalid mesh type, holding connection (' + obj.remoteaddrport + ').');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Mark when this device connected
|
||||||
|
obj.connectTime = Date.now();
|
||||||
|
db.Set({ _id: 'lc' + obj.dbNodeKey, type: 'lastconnect', domain: domain.id, time: obj.connectTime, addr: obj.remoteaddrport });
|
||||||
|
|
||||||
|
// This node does not exist, create it.
|
||||||
|
var device = { type: 'node', mtype: mesh.mtype, _id: obj.dbNodeKey, icon: obj.agentInfo.platformType, meshid: obj.dbMeshKey, name: obj.agentInfo.computerName, rname: obj.agentInfo.computerName, domain: domain.id, agent: { ver: obj.agentInfo.agentVersion, id: obj.agentInfo.agentId, caps: obj.agentInfo.capabilities }, host: null };
|
||||||
|
db.Set(device);
|
||||||
|
|
||||||
|
// Event the new node
|
||||||
|
if (obj.agentInfo.capabilities & 0x20) {
|
||||||
|
// This is a temporary agent, don't log.
|
||||||
|
parent.parent.DispatchEvent(['*', obj.dbMeshKey], obj, { etype: 'node', action: 'addnode', node: device, domain: domain.id, nolog: 1 });
|
||||||
|
} else {
|
||||||
|
parent.parent.DispatchEvent(['*', obj.dbMeshKey], obj, { etype: 'node', action: 'addnode', node: device, msg: ('Added device ' + obj.agentInfo.computerName + ' to mesh ' + mesh.name), domain: domain.id });
|
||||||
|
}
|
||||||
|
|
||||||
|
completeAgentConnection3();
|
||||||
|
}
|
||||||
|
|
||||||
|
function completeAgentConnection3() {
|
||||||
// Check if this agent is already connected
|
// Check if this agent is already connected
|
||||||
const dupAgent = parent.wsagents[obj.dbNodeKey];
|
const dupAgent = parent.wsagents[obj.dbNodeKey];
|
||||||
parent.wsagents[obj.dbNodeKey] = obj;
|
parent.wsagents[obj.dbNodeKey] = obj;
|
||||||
@ -784,7 +809,6 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
agentCoreIsStable(); // No updates needed, agent is ready to go.
|
agentCoreIsStable(); // No updates needed, agent is ready to go.
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Take a basic Intel AMT policy and add all server information to it, making it ready to send to this agent.
|
// Take a basic Intel AMT policy and add all server information to it, making it ready to send to this agent.
|
||||||
|
71
mpsserver.js
71
mpsserver.js
@ -128,6 +128,7 @@ module.exports.CreateMpsServer = function (parent, db, args, certificates) {
|
|||||||
var disconnectCommandCount = 0;
|
var disconnectCommandCount = 0;
|
||||||
var socketClosedCount = 0;
|
var socketClosedCount = 0;
|
||||||
var socketErrorCount = 0;
|
var socketErrorCount = 0;
|
||||||
|
var maxDomainDevicesReached = 0;
|
||||||
|
|
||||||
// Return statistics about this MPS server
|
// Return statistics about this MPS server
|
||||||
obj.getStats = function () {
|
obj.getStats = function () {
|
||||||
@ -153,7 +154,8 @@ module.exports.CreateMpsServer = function (parent, db, args, certificates) {
|
|||||||
channelCloseCount: channelCloseCount,
|
channelCloseCount: channelCloseCount,
|
||||||
disconnectCommandCount: disconnectCommandCount,
|
disconnectCommandCount: disconnectCommandCount,
|
||||||
socketClosedCount: socketClosedCount,
|
socketClosedCount: socketClosedCount,
|
||||||
socketErrorCount: socketErrorCount
|
socketErrorCount: socketErrorCount,
|
||||||
|
maxDomainDevicesReached : maxDomainDevicesReached
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -189,6 +191,11 @@ module.exports.CreateMpsServer = function (parent, db, args, certificates) {
|
|||||||
var xx = socket.tag.clientCert.subject.O.split('/');
|
var xx = socket.tag.clientCert.subject.O.split('/');
|
||||||
if (xx.length == 1) { meshid = xx[0]; } else { domainid = xx[0].toLowerCase(); meshid = xx[1]; }
|
if (xx.length == 1) { meshid = xx[0]; } else { domainid = xx[0].toLowerCase(); meshid = xx[1]; }
|
||||||
|
|
||||||
|
// Check the incoming domain
|
||||||
|
var domain = obj.parent.config.domains[domainid];
|
||||||
|
if (domain == null) { console.log('CIRA connection for invalid domain. meshid: ' + meshid); socket.end(); return; }
|
||||||
|
|
||||||
|
socket.tag.domain = domain;
|
||||||
socket.tag.domainid = domainid;
|
socket.tag.domainid = domainid;
|
||||||
socket.tag.meshid = 'mesh/' + domainid + '/' + meshid;
|
socket.tag.meshid = 'mesh/' + domainid + '/' + meshid;
|
||||||
socket.tag.nodeid = 'node/' + domainid + '/' + require('crypto').createHash('sha384').update(common.hex2rstr(socket.tag.clientCert.modulus, 'binary')).digest('base64').replace(/\+/g, '@').replace(/\//g, '$');
|
socket.tag.nodeid = 'node/' + domainid + '/' + require('crypto').createHash('sha384').update(common.hex2rstr(socket.tag.clientCert.modulus, 'binary')).digest('base64').replace(/\+/g, '@').replace(/\//g, '$');
|
||||||
@ -203,6 +210,16 @@ module.exports.CreateMpsServer = function (parent, db, args, certificates) {
|
|||||||
obj.db.Get(socket.tag.nodeid, function (err, nodes) {
|
obj.db.Get(socket.tag.nodeid, function (err, nodes) {
|
||||||
if ((nodes == null) || (nodes.length !== 1)) {
|
if ((nodes == null) || (nodes.length !== 1)) {
|
||||||
if (mesh.mtype == 1) {
|
if (mesh.mtype == 1) {
|
||||||
|
// Check if we already have too many devices for this domain
|
||||||
|
if (domain.limits && (typeof domain.limits.maxdevices == 'number')) {
|
||||||
|
db.isMaxType(domain.limits.maxdevices, 'node', domain.id, function (ismax, count) {
|
||||||
|
if (ismax == true) {
|
||||||
|
// Too many devices in this domain.
|
||||||
|
maxDomainDevicesReached++;
|
||||||
|
console.log('Too many devices on this domain to accept the CIRA connection. meshid: ' + socket.tag.meshid);
|
||||||
|
socket.end();
|
||||||
|
} else {
|
||||||
|
// We are under the limit, create the new device.
|
||||||
// Node is not in the database, add it. Credentials will be empty until added by the user.
|
// Node is not in the database, add it. Credentials will be empty until added by the user.
|
||||||
var device = { type: 'node', mtype: 1, _id: socket.tag.nodeid, meshid: socket.tag.meshid, name: socket.tag.name, host: null, domain: domainid, intelamt: { user: '', pass: '', tls: 0, state: 2 } };
|
var device = { type: 'node', mtype: 1, _id: socket.tag.nodeid, meshid: socket.tag.meshid, name: socket.tag.name, host: null, domain: domainid, intelamt: { user: '', pass: '', tls: 0, state: 2 } };
|
||||||
obj.db.Set(device);
|
obj.db.Set(device);
|
||||||
@ -213,6 +230,25 @@ module.exports.CreateMpsServer = function (parent, db, args, certificates) {
|
|||||||
if (device2.intelamt.pass != null) delete device2.intelamt.pass; // Remove the Intel AMT password before eventing this.
|
if (device2.intelamt.pass != null) delete device2.intelamt.pass; // Remove the Intel AMT password before eventing this.
|
||||||
var change = 'CIRA added device ' + socket.tag.name + ' to mesh ' + mesh.name;
|
var change = 'CIRA added device ' + socket.tag.name + ' to mesh ' + mesh.name;
|
||||||
obj.parent.DispatchEvent(['*', socket.tag.meshid], obj, { etype: 'node', action: 'addnode', node: device2, msg: change, domain: domainid });
|
obj.parent.DispatchEvent(['*', socket.tag.meshid], obj, { etype: 'node', action: 'addnode', node: device2, msg: change, domain: domainid });
|
||||||
|
|
||||||
|
// Add the connection to the MPS connection list
|
||||||
|
obj.ciraConnections[socket.tag.nodeid] = socket;
|
||||||
|
obj.parent.SetConnectivityState(socket.tag.meshid, socket.tag.nodeid, socket.tag.connectTime, 2, 7); // TODO: Right now report power state as "present" (7) until we can poll.
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
// Node is not in the database, add it. Credentials will be empty until added by the user.
|
||||||
|
var device = { type: 'node', mtype: 1, _id: socket.tag.nodeid, meshid: socket.tag.meshid, name: socket.tag.name, host: null, domain: domainid, intelamt: { user: '', pass: '', tls: 0, state: 2 } };
|
||||||
|
obj.db.Set(device);
|
||||||
|
|
||||||
|
// Event the new node
|
||||||
|
addedTlsDeviceCount++;
|
||||||
|
var device2 = common.Clone(device);
|
||||||
|
if (device2.intelamt.pass != null) delete device2.intelamt.pass; // Remove the Intel AMT password before eventing this.
|
||||||
|
var change = 'CIRA added device ' + socket.tag.name + ' to mesh ' + mesh.name;
|
||||||
|
obj.parent.DispatchEvent(['*', socket.tag.meshid], obj, { etype: 'node', action: 'addnode', node: device2, msg: change, domain: domainid });
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// New CIRA connection for unknown node, disconnect.
|
// New CIRA connection for unknown node, disconnect.
|
||||||
unknownTlsNodeCount++;
|
unknownTlsNodeCount++;
|
||||||
@ -312,6 +348,9 @@ module.exports.CreateMpsServer = function (parent, db, args, certificates) {
|
|||||||
// Intel AMT GUID (socket.tag.SystemId) will be used as NodeID
|
// Intel AMT GUID (socket.tag.SystemId) will be used as NodeID
|
||||||
var systemid = socket.tag.SystemId.split('-').join('');
|
var systemid = socket.tag.SystemId.split('-').join('');
|
||||||
var nodeid = Buffer.from(systemid + systemid + systemid, 'hex').toString('base64').replace(/\+/g, '@').replace(/\//g, '$');
|
var nodeid = Buffer.from(systemid + systemid + systemid, 'hex').toString('base64').replace(/\+/g, '@').replace(/\//g, '$');
|
||||||
|
var domain = obj.parent.config.domains[mesh.domain];
|
||||||
|
socket.tag.domain = domain;
|
||||||
|
socket.tag.domainid = mesh.domain;
|
||||||
socket.tag.name = '';
|
socket.tag.name = '';
|
||||||
socket.tag.nodeid = 'node/' + mesh.domain + '/' + nodeid; // Turn 16bit systemid guid into 48bit nodeid that is base64 encoded
|
socket.tag.nodeid = 'node/' + mesh.domain + '/' + nodeid; // Turn 16bit systemid guid into 48bit nodeid that is base64 encoded
|
||||||
socket.tag.meshid = mesh._id;
|
socket.tag.meshid = mesh._id;
|
||||||
@ -319,6 +358,16 @@ module.exports.CreateMpsServer = function (parent, db, args, certificates) {
|
|||||||
|
|
||||||
obj.db.Get(socket.tag.nodeid, function (err, nodes) {
|
obj.db.Get(socket.tag.nodeid, function (err, nodes) {
|
||||||
if ((nodes == null) || (nodes.length !== 1)) {
|
if ((nodes == null) || (nodes.length !== 1)) {
|
||||||
|
// Check if we already have too many devices for this domain
|
||||||
|
if (domain.limits && (typeof domain.limits.maxdevices == 'number')) {
|
||||||
|
db.isMaxType(domain.limits.maxdevices, 'node', mesh.domain, function (ismax, count) {
|
||||||
|
if (ismax == true) {
|
||||||
|
// Too many devices in this domain.
|
||||||
|
maxDomainDevicesReached++;
|
||||||
|
console.log('Too many devices on this domain to accept the CIRA connection. meshid: ' + socket.tag.meshid);
|
||||||
|
socket.end();
|
||||||
|
} else {
|
||||||
|
// We are under the limit, create the new device.
|
||||||
// Node is not in the database, add it. Credentials will be empty until added by the user.
|
// Node is not in the database, add it. Credentials will be empty until added by the user.
|
||||||
var device = { type: 'node', mtype: 1, _id: socket.tag.nodeid, meshid: socket.tag.meshid, name: socket.tag.name, host: null, domain: mesh.domain, intelamt: { user: '', pass: '', tls: 0, state: 2 } };
|
var device = { type: 'node', mtype: 1, _id: socket.tag.nodeid, meshid: socket.tag.meshid, name: socket.tag.name, host: null, domain: mesh.domain, intelamt: { user: '', pass: '', tls: 0, state: 2 } };
|
||||||
obj.db.Set(device);
|
obj.db.Set(device);
|
||||||
@ -329,6 +378,26 @@ module.exports.CreateMpsServer = function (parent, db, args, certificates) {
|
|||||||
if (device2.intelamt.pass != null) delete device2.intelamt.pass; // Remove the Intel AMT password before eventing this.
|
if (device2.intelamt.pass != null) delete device2.intelamt.pass; // Remove the Intel AMT password before eventing this.
|
||||||
var change = 'CIRA added device ' + socket.tag.name + ' to group ' + mesh.name;
|
var change = 'CIRA added device ' + socket.tag.name + ' to group ' + mesh.name;
|
||||||
obj.parent.DispatchEvent(['*', socket.tag.meshid], obj, { etype: 'node', action: 'addnode', node: device2, msg: change, domain: mesh.domain });
|
obj.parent.DispatchEvent(['*', socket.tag.meshid], obj, { etype: 'node', action: 'addnode', node: device2, msg: change, domain: mesh.domain });
|
||||||
|
|
||||||
|
// Add the connection to the MPS connection list
|
||||||
|
obj.ciraConnections[socket.tag.nodeid] = socket;
|
||||||
|
obj.parent.SetConnectivityState(socket.tag.meshid, socket.tag.nodeid, socket.tag.connectTime, 2, 7); // TODO: Right now report power state as "present" (7) until we can poll.
|
||||||
|
SendUserAuthSuccess(socket); // Notify the auth success on the CIRA connection
|
||||||
|
}
|
||||||
|
});
|
||||||
|
return;
|
||||||
|
} else {
|
||||||
|
// Node is not in the database, add it. Credentials will be empty until added by the user.
|
||||||
|
var device = { type: 'node', mtype: 1, _id: socket.tag.nodeid, meshid: socket.tag.meshid, name: socket.tag.name, host: null, domain: mesh.domain, intelamt: { user: '', pass: '', tls: 0, state: 2 } };
|
||||||
|
obj.db.Set(device);
|
||||||
|
|
||||||
|
// Event the new node
|
||||||
|
addedDeviceCount++;
|
||||||
|
var device2 = common.Clone(device);
|
||||||
|
if (device2.intelamt.pass != null) delete device2.intelamt.pass; // Remove the Intel AMT password before eventing this.
|
||||||
|
var change = 'CIRA added device ' + socket.tag.name + ' to group ' + mesh.name;
|
||||||
|
obj.parent.DispatchEvent(['*', socket.tag.meshid], obj, { etype: 'node', action: 'addnode', node: device2, msg: change, domain: mesh.domain });
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
// Node is already present
|
// Node is already present
|
||||||
var node = nodes[0];
|
var node = nodes[0];
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "meshcentral",
|
"name": "meshcentral",
|
||||||
"version": "0.3.5-z",
|
"version": "0.3.6-a",
|
||||||
"keywords": [
|
"keywords": [
|
||||||
"Remote Management",
|
"Remote Management",
|
||||||
"Intel AMT",
|
"Intel AMT",
|
||||||
|
@ -72,6 +72,7 @@
|
|||||||
"__UserConsentFlags__" : "Set to: 1 for desktop, 2 for terminal, 3 for files, 7 for all",
|
"__UserConsentFlags__" : "Set to: 1 for desktop, 2 for terminal, 3 for files, 7 for all",
|
||||||
"_UserConsentFlags" : 7,
|
"_UserConsentFlags" : 7,
|
||||||
"_Limits": {
|
"_Limits": {
|
||||||
|
"_MaxDevices": 100,
|
||||||
"_MaxUserAccounts": 100,
|
"_MaxUserAccounts": 100,
|
||||||
"_MaxUserSessions": 100,
|
"_MaxUserSessions": 100,
|
||||||
"_MaxAgentSessions": 100,
|
"_MaxAgentSessions": 100,
|
||||||
|
@ -10189,7 +10189,7 @@ var QRCode;!function(){function a(a){this.mode=c.MODE_8BIT_BYTE,this.data=a,this
|
|||||||
|
|
||||||
function addDeviceAttribute(name, value) { return '<tr><td class=style7>' + name + '</td><td class=style9>' + value + '</td></tr>'; }
|
function addDeviceAttribute(name, value) { return '<tr><td class=style7>' + name + '</td><td class=style9>' + value + '</td></tr>'; }
|
||||||
|
|
||||||
function editDeviceAmtSettings(nodeid, func) {
|
function editDeviceAmtSettings(nodeid, func, arg) {
|
||||||
if (xxdialogMode) return;
|
if (xxdialogMode) return;
|
||||||
var x = '', node = getNodeFromId(nodeid), buttons = 3, meshrights = getNodeRights(nodeid);
|
var x = '', node = getNodeFromId(nodeid), buttons = 3, meshrights = getNodeRights(nodeid);
|
||||||
if ((meshrights & 4) == 0) return;
|
if ((meshrights & 4) == 0) return;
|
||||||
@ -10197,7 +10197,7 @@ var QRCode;!function(){function a(a){this.mode=c.MODE_8BIT_BYTE,this.data=a,this
|
|||||||
x += addHtmlValue('Password', '<input id=dp10password type=password style=width:230px autocomplete=nope maxlength=32 onchange=validateDeviceAmtSettings() onkeyup=validateDeviceAmtSettings() />');
|
x += addHtmlValue('Password', '<input id=dp10password type=password style=width:230px autocomplete=nope maxlength=32 onchange=validateDeviceAmtSettings() onkeyup=validateDeviceAmtSettings() />');
|
||||||
x += addHtmlValue('Security', '<select id=dp10tls style=width:236px><option value=0>No TLS security</option><option value=1>TLS security required</option></select>');
|
x += addHtmlValue('Security', '<select id=dp10tls style=width:236px><option value=0>No TLS security</option><option value=1>TLS security required</option></select>');
|
||||||
if ((node.intelamt.user != null) && (node.intelamt.user != '')) { buttons = 7; }
|
if ((node.intelamt.user != null) && (node.intelamt.user != '')) { buttons = 7; }
|
||||||
setDialogMode(2, "Edit Intel® AMT credentials", buttons, editDeviceAmtSettingsEx, x, { node: node, func: func });
|
setDialogMode(2, "Edit Intel® AMT credentials", buttons, editDeviceAmtSettingsEx, x, { node: node, func: func, arg: arg });
|
||||||
if ((node.intelamt.user != null) && (node.intelamt.user != '')) { Q('dp10username').value = node.intelamt.user; } else { Q('dp10username').value = 'admin'; }
|
if ((node.intelamt.user != null) && (node.intelamt.user != '')) { Q('dp10username').value = node.intelamt.user; } else { Q('dp10username').value = 'admin'; }
|
||||||
Q('dp10tls').value = node.intelamt.tls;
|
Q('dp10tls').value = node.intelamt.tls;
|
||||||
validateDeviceAmtSettings();
|
validateDeviceAmtSettings();
|
||||||
@ -10220,7 +10220,7 @@ var QRCode;!function(){function a(a){this.mode=c.MODE_8BIT_BYTE,this.data=a,this
|
|||||||
meshserver.send({ action: 'changedevice', nodeid: tag.node._id, intelamt: { user: amtuser, pass: amtpass, tls: Q('dp10tls').value } });
|
meshserver.send({ action: 'changedevice', nodeid: tag.node._id, intelamt: { user: amtuser, pass: amtpass, tls: Q('dp10tls').value } });
|
||||||
tag.node.intelamt.user = amtuser;
|
tag.node.intelamt.user = amtuser;
|
||||||
tag.node.intelamt.tls = Q('dp10tls').value;
|
tag.node.intelamt.tls = Q('dp10tls').value;
|
||||||
if (tag.func) { setTimeout(tag.func, 300); }
|
if (tag.func) { setTimeout(function () { tag.func(null, tag.arg); }, 300); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -10519,7 +10519,7 @@ var QRCode;!function(){function a(a){this.mode=c.MODE_8BIT_BYTE,this.data=a,this
|
|||||||
desktopNode = currentNode;
|
desktopNode = currentNode;
|
||||||
if (contype == 2) {
|
if (contype == 2) {
|
||||||
// Setup the Intel AMT remote desktop
|
// Setup the Intel AMT remote desktop
|
||||||
if ((desktopNode.intelamt.user == null) || (desktopNode.intelamt.user == '')) { editDeviceAmtSettings(desktopNode._id, connectDesktop); return; }
|
if ((desktopNode.intelamt.user == null) || (desktopNode.intelamt.user == '')) { editDeviceAmtSettings(desktopNode._id, connectDesktop, 2); return; }
|
||||||
desktop = CreateAmtRedirect(CreateAmtRemoteDesktop('Desk'), authCookie);
|
desktop = CreateAmtRedirect(CreateAmtRemoteDesktop('Desk'), authCookie);
|
||||||
desktop.debugmode = debugmode;
|
desktop.debugmode = debugmode;
|
||||||
desktop.onStateChanged = onDesktopStateChange;
|
desktop.onStateChanged = onDesktopStateChange;
|
||||||
@ -11111,7 +11111,7 @@ var QRCode;!function(){function a(a){this.mode=c.MODE_8BIT_BYTE,this.data=a,this
|
|||||||
if (!terminal) {
|
if (!terminal) {
|
||||||
if (contype == 2) {
|
if (contype == 2) {
|
||||||
// Setup the Intel AMT terminal
|
// Setup the Intel AMT terminal
|
||||||
if ((terminalNode.intelamt.user == null) || (terminalNode.intelamt.user == '')) { editDeviceAmtSettings(terminalNode._id, connectTerminal); return; }
|
if ((terminalNode.intelamt.user == null) || (terminalNode.intelamt.user == '')) { editDeviceAmtSettings(terminalNode._id, connectTerminal, 2); return; }
|
||||||
var termoptions = {};
|
var termoptions = {};
|
||||||
if (Q('termSizeList').value == 2) { termoptions.width = 100; termoptions.height = 30; }
|
if (Q('termSizeList').value == 2) { termoptions.width = 100; termoptions.height = 30; }
|
||||||
terminal = CreateAmtRedirect(CreateAmtRemoteTerminal('Term', termoptions), authCookie);
|
terminal = CreateAmtRedirect(CreateAmtRemoteTerminal('Term', termoptions), authCookie);
|
||||||
|
@ -4141,7 +4141,7 @@
|
|||||||
|
|
||||||
function addDeviceAttribute(name, value) { return '<tr><td class=style7>' + name + '</td><td class=style9>' + value + '</td></tr>'; }
|
function addDeviceAttribute(name, value) { return '<tr><td class=style7>' + name + '</td><td class=style9>' + value + '</td></tr>'; }
|
||||||
|
|
||||||
function editDeviceAmtSettings(nodeid, func) {
|
function editDeviceAmtSettings(nodeid, func, arg) {
|
||||||
if (xxdialogMode) return;
|
if (xxdialogMode) return;
|
||||||
var x = '', node = getNodeFromId(nodeid), buttons = 3, meshrights = getNodeRights(nodeid);
|
var x = '', node = getNodeFromId(nodeid), buttons = 3, meshrights = getNodeRights(nodeid);
|
||||||
if ((meshrights & 4) == 0) return;
|
if ((meshrights & 4) == 0) return;
|
||||||
@ -4149,7 +4149,7 @@
|
|||||||
x += addHtmlValue('Password', '<input id=dp10password type=password style=width:230px autocomplete=nope maxlength=32 onchange=validateDeviceAmtSettings() onkeyup=validateDeviceAmtSettings() />');
|
x += addHtmlValue('Password', '<input id=dp10password type=password style=width:230px autocomplete=nope maxlength=32 onchange=validateDeviceAmtSettings() onkeyup=validateDeviceAmtSettings() />');
|
||||||
x += addHtmlValue('Security', '<select id=dp10tls style=width:236px><option value=0>No TLS security</option><option value=1>TLS security required</option></select>');
|
x += addHtmlValue('Security', '<select id=dp10tls style=width:236px><option value=0>No TLS security</option><option value=1>TLS security required</option></select>');
|
||||||
if ((node.intelamt.user != null) && (node.intelamt.user != '')) { buttons = 7; }
|
if ((node.intelamt.user != null) && (node.intelamt.user != '')) { buttons = 7; }
|
||||||
setDialogMode(2, "Edit Intel® AMT credentials", buttons, editDeviceAmtSettingsEx, x, { node: node, func: func });
|
setDialogMode(2, "Edit Intel® AMT credentials", buttons, editDeviceAmtSettingsEx, x, { node: node, func: func, arg: arg });
|
||||||
if ((node.intelamt.user != null) && (node.intelamt.user != '')) { Q('dp10username').value = node.intelamt.user; } else { Q('dp10username').value = 'admin'; }
|
if ((node.intelamt.user != null) && (node.intelamt.user != '')) { Q('dp10username').value = node.intelamt.user; } else { Q('dp10username').value = 'admin'; }
|
||||||
Q('dp10tls').value = node.intelamt.tls;
|
Q('dp10tls').value = node.intelamt.tls;
|
||||||
validateDeviceAmtSettings();
|
validateDeviceAmtSettings();
|
||||||
@ -4172,7 +4172,7 @@
|
|||||||
meshserver.send({ action: 'changedevice', nodeid: tag.node._id, intelamt: { user: amtuser, pass: amtpass, tls: Q('dp10tls').value } });
|
meshserver.send({ action: 'changedevice', nodeid: tag.node._id, intelamt: { user: amtuser, pass: amtpass, tls: Q('dp10tls').value } });
|
||||||
tag.node.intelamt.user = amtuser;
|
tag.node.intelamt.user = amtuser;
|
||||||
tag.node.intelamt.tls = Q('dp10tls').value;
|
tag.node.intelamt.tls = Q('dp10tls').value;
|
||||||
if (tag.func) { setTimeout(tag.func, 300); }
|
if (tag.func) { setTimeout(function () { tag.func(null, tag.arg); }, 300); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4471,7 +4471,7 @@
|
|||||||
desktopNode = currentNode;
|
desktopNode = currentNode;
|
||||||
if (contype == 2) {
|
if (contype == 2) {
|
||||||
// Setup the Intel AMT remote desktop
|
// Setup the Intel AMT remote desktop
|
||||||
if ((desktopNode.intelamt.user == null) || (desktopNode.intelamt.user == '')) { editDeviceAmtSettings(desktopNode._id, connectDesktop); return; }
|
if ((desktopNode.intelamt.user == null) || (desktopNode.intelamt.user == '')) { editDeviceAmtSettings(desktopNode._id, connectDesktop, 2); return; }
|
||||||
desktop = CreateAmtRedirect(CreateAmtRemoteDesktop('Desk'), authCookie);
|
desktop = CreateAmtRedirect(CreateAmtRemoteDesktop('Desk'), authCookie);
|
||||||
desktop.debugmode = debugmode;
|
desktop.debugmode = debugmode;
|
||||||
desktop.onStateChanged = onDesktopStateChange;
|
desktop.onStateChanged = onDesktopStateChange;
|
||||||
@ -5063,7 +5063,7 @@
|
|||||||
if (!terminal) {
|
if (!terminal) {
|
||||||
if (contype == 2) {
|
if (contype == 2) {
|
||||||
// Setup the Intel AMT terminal
|
// Setup the Intel AMT terminal
|
||||||
if ((terminalNode.intelamt.user == null) || (terminalNode.intelamt.user == '')) { editDeviceAmtSettings(terminalNode._id, connectTerminal); return; }
|
if ((terminalNode.intelamt.user == null) || (terminalNode.intelamt.user == '')) { editDeviceAmtSettings(terminalNode._id, connectTerminal, 2); return; }
|
||||||
var termoptions = {};
|
var termoptions = {};
|
||||||
if (Q('termSizeList').value == 2) { termoptions.width = 100; termoptions.height = 30; }
|
if (Q('termSizeList').value == 2) { termoptions.width = 100; termoptions.height = 30; }
|
||||||
terminal = CreateAmtRedirect(CreateAmtRemoteTerminal('Term', termoptions), authCookie);
|
terminal = CreateAmtRedirect(CreateAmtRemoteTerminal('Term', termoptions), authCookie);
|
||||||
|
@ -261,7 +261,8 @@ module.exports.CreateWebServer = function (parent, db, args, certificates) {
|
|||||||
invalidMeshTypeCount: 0,
|
invalidMeshTypeCount: 0,
|
||||||
invalidDomainMesh2Count: 0,
|
invalidDomainMesh2Count: 0,
|
||||||
invalidMeshType2Count: 0,
|
invalidMeshType2Count: 0,
|
||||||
duplicateAgentCount: 0
|
duplicateAgentCount: 0,
|
||||||
|
maxDomainDevicesReached: 0
|
||||||
}
|
}
|
||||||
obj.getAgentStats = function () { return obj.agentStats; }
|
obj.getAgentStats = function () { return obj.agentStats; }
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user