mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-11 15:03:20 -05:00
Improved MEI/SMBios in meshcore.js
This commit is contained in:
parent
0cbd98e7d6
commit
5f84e4f4ba
@ -73,7 +73,6 @@ function createMeshCore(agent) {
|
|||||||
var fs = require('fs');
|
var fs = require('fs');
|
||||||
var rtc = require('ILibWebRTC');
|
var rtc = require('ILibWebRTC');
|
||||||
var processManager = require('process-manager');
|
var processManager = require('process-manager');
|
||||||
var SMBiosTables = require('smbios');
|
|
||||||
var amtMei = null, amtLms = null, amtLmsState = 0;
|
var amtMei = null, amtLms = null, amtLmsState = 0;
|
||||||
var amtMeiConnected = 0, amtMeiTmpState = null;
|
var amtMeiConnected = 0, amtMeiTmpState = null;
|
||||||
var wifiScannerLib = null;
|
var wifiScannerLib = null;
|
||||||
@ -81,7 +80,25 @@ function createMeshCore(agent) {
|
|||||||
var networkMonitor = null;
|
var networkMonitor = null;
|
||||||
var amtscanner = null;
|
var amtscanner = null;
|
||||||
var nextTunnelIndex = 1;
|
var nextTunnelIndex = 1;
|
||||||
|
|
||||||
|
// If we are running in Duktape, agent will be null
|
||||||
|
if (agent == null) {
|
||||||
|
// Running in native agent, Import libraries
|
||||||
|
db = require('SimpleDataStore').Shared();
|
||||||
|
sha = require('SHA256Stream');
|
||||||
|
mesh = require('MeshAgent');
|
||||||
|
childProcess = require('child_process');
|
||||||
|
if (mesh.hasKVM == 1) { // if the agent is compiled with KVM support
|
||||||
|
// Check if this computer supports a desktop
|
||||||
|
try { if ((process.platform == 'win32') || (process.platform == 'darwin') || (require('monitor-info').kvm_x11_support)) { obj.meshCoreCapabilities |= 1; } } catch (ex) { }
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// Running in nodejs
|
||||||
|
obj.meshCoreInfo += '-NodeJS';
|
||||||
|
obj.meshCoreCapabilities = 8;
|
||||||
|
mesh = agent.getMeshApi();
|
||||||
|
}
|
||||||
|
|
||||||
// Get the operating system description string
|
// Get the operating system description string
|
||||||
var osDesc = null;
|
var osDesc = null;
|
||||||
try { require('os').name().then(function (v) { osDesc = v; if (mesh.isControlChannelConnected) { mesh.SendCommand({ "action": "coreinfo", "value": obj.meshCoreInfo, "osdesc": osDesc }); } }); } catch (ex) { }
|
try { require('os').name().then(function (v) { osDesc = v; if (mesh.isControlChannelConnected) { mesh.SendCommand({ "action": "coreinfo", "value": obj.meshCoreInfo, "osdesc": osDesc }); } }); } catch (ex) { }
|
||||||
@ -118,15 +135,29 @@ function createMeshCore(agent) {
|
|||||||
amtscanner = new AMTScannerModule();
|
amtscanner = new AMTScannerModule();
|
||||||
//amtscanner.on('found', function (data) { if (typeof data != 'string') { data = JSON.stringify(data, null, " "); } sendConsoleText(data); });
|
//amtscanner.on('found', function (data) { if (typeof data != 'string') { data = JSON.stringify(data, null, " "); } sendConsoleText(data); });
|
||||||
} catch (ex) { amtscanner = null; }
|
} catch (ex) { amtscanner = null; }
|
||||||
|
|
||||||
// Try to load up the MEI module
|
// Fetch the SMBios Tables
|
||||||
try {
|
var SMBiosTables = null;
|
||||||
var amtMeiLib = require('amt-mei');
|
var SMBiosTablesRaw = null;
|
||||||
amtMei = new amtMeiLib();
|
require('smbios').get(function (data) {
|
||||||
amtMei.on('error', function (e) { amtMeiLib = null; amtMei = null; amtMeiConnected = -1; });
|
if (data != null) {
|
||||||
amtMeiConnected = 2;
|
SMBiosTablesRaw = data;
|
||||||
sendPeriodicServerUpdate(1);
|
SMBiosTables = require('smbios').parse(data)
|
||||||
} catch (ex) { amtMeiLib = null; amtMei = null; amtMeiConnected = -1; }
|
if (mesh.isControlChannelConnected) { mesh.SendCommand({ "action": "smbios", "value": SMBiosTablesRaw }); }
|
||||||
|
|
||||||
|
// If SMBios tables say that AMT is present, try to connect MEI
|
||||||
|
if (SMBiosTables.amtInfo && (SMBiosTables.amtInfo.AMT == true)) {
|
||||||
|
// Try to load up the MEI module
|
||||||
|
try {
|
||||||
|
var amtMeiLib = require('amt-mei');
|
||||||
|
amtMei = new amtMeiLib();
|
||||||
|
amtMei.on('error', function (e) { amtMeiLib = null; amtMei = null; amtMeiConnected = -1; });
|
||||||
|
amtMeiConnected = 2;
|
||||||
|
sendPeriodicServerUpdate(1);
|
||||||
|
} catch (ex) { amtMeiLib = null; amtMei = null; amtMeiConnected = -1; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
// Try to load up the WIFI scanner
|
// Try to load up the WIFI scanner
|
||||||
try {
|
try {
|
||||||
@ -135,24 +166,6 @@ function createMeshCore(agent) {
|
|||||||
wifiScanner.on('accessPoint', function (data) { sendConsoleText(JSON.stringify(data)); });
|
wifiScanner.on('accessPoint', function (data) { sendConsoleText(JSON.stringify(data)); });
|
||||||
} catch (ex) { wifiScannerLib = null; wifiScanner = null; }
|
} catch (ex) { wifiScannerLib = null; wifiScanner = null; }
|
||||||
|
|
||||||
// If we are running in Duktape, agent will be null
|
|
||||||
if (agent == null) {
|
|
||||||
// Running in native agent, Import libraries
|
|
||||||
db = require('SimpleDataStore').Shared();
|
|
||||||
sha = require('SHA256Stream');
|
|
||||||
mesh = require('MeshAgent');
|
|
||||||
childProcess = require('child_process');
|
|
||||||
if (mesh.hasKVM == 1) { // if the agent is compiled with KVM support
|
|
||||||
// Check if this computer supports a desktop
|
|
||||||
try { if ((process.platform == 'win32') || (process.platform == 'darwin') || (require('monitor-info').kvm_x11_support)) { obj.meshCoreCapabilities |= 1; } } catch (ex) { }
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
// Running in nodejs
|
|
||||||
obj.meshCoreInfo += '-NodeJS';
|
|
||||||
obj.meshCoreCapabilities = 8;
|
|
||||||
mesh = agent.getMeshApi();
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get our location (lat/long) using our public IP address
|
// Get our location (lat/long) using our public IP address
|
||||||
var getIpLocationDataExInProgress = false;
|
var getIpLocationDataExInProgress = false;
|
||||||
var getIpLocationDataExCounts = [0, 0];
|
var getIpLocationDataExCounts = [0, 0];
|
||||||
@ -972,31 +985,22 @@ function createMeshCore(agent) {
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'smbios': {
|
case 'smbios': {
|
||||||
if (SMBiosTables != null) {
|
if (SMBiosTables == null) { response = 'SMBios tables not available.'; } else { response = objToString(SMBiosTables, 0, ' ', true); }
|
||||||
SMBiosTables.get(function (data) {
|
|
||||||
if (data == null) { sendConsoleText('Unable to get SM BIOS data.', sessionid); return; }
|
|
||||||
sendConsoleText(objToString(SMBiosTables.parse(data), 0, ' ', true), sessionid);
|
|
||||||
});
|
|
||||||
} else { response = 'SM BIOS module not available.'; }
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'rawsmbios': {
|
case 'rawsmbios': {
|
||||||
if (SMBiosTables != null) {
|
if (SMBiosTablesRaw == null) { response = 'SMBios tables not available.'; } else {
|
||||||
SMBiosTables.get(function (data) {
|
response = '';
|
||||||
if (data == null) { sendConsoleText('Unable to get SM BIOS data.', sessionid); return; }
|
for (var i in SMBiosTablesRaw) {
|
||||||
var out = '';
|
var header = false;
|
||||||
for (var i in data) {
|
for (var j in SMBiosTablesRaw[i]) {
|
||||||
var header = false;
|
if (SMBiosTablesRaw[i][j].length > 0) {
|
||||||
for (var j in data[i]) {
|
if (header == false) { response += ('Table type #' + i + ((require('smbios').smTableTypes[i] == null) ? '' : (', ' + require('smbios').smTableTypes[i]))) + '\r\n'; header = true; }
|
||||||
if (data[i][j].length > 0) {
|
response += (' ' + SMBiosTablesRaw[i][j].toString('hex')) + '\r\n';
|
||||||
if (header == false) { out += ('Table type #' + i + ((SMBiosTables.smTableTypes[i] == null) ? '' : (', ' + SMBiosTables.smTableTypes[i]))) + '\r\n'; header = true; }
|
|
||||||
out += (' ' + data[i][j].toString('hex')) + '\r\n';
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
sendConsoleText(out, sessionid);
|
}
|
||||||
});
|
}
|
||||||
} else { response = 'SM BIOS module not available.'; }
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'eval': { // Eval JavaScript
|
case 'eval': { // Eval JavaScript
|
||||||
@ -1358,11 +1362,14 @@ function createMeshCore(agent) {
|
|||||||
var oldNodeId = db.Get('OldNodeId');
|
var oldNodeId = db.Get('OldNodeId');
|
||||||
if (oldNodeId != null) { mesh.SendCommand({ action: 'mc1migration', oldnodeid: oldNodeId }); }
|
if (oldNodeId != null) { mesh.SendCommand({ action: 'mc1migration', oldnodeid: oldNodeId }); }
|
||||||
|
|
||||||
// Update the server wtih basic info
|
// Update the server with basic info
|
||||||
var r = { "action": "coreinfo", "value": obj.meshCoreInfo, "caps": obj.meshCoreCapabilities };
|
var r = { "action": "coreinfo", "value": obj.meshCoreInfo, "caps": obj.meshCoreCapabilities };
|
||||||
if (osDesc != null) { r.osdesc = osDesc; }
|
if (osDesc != null) { r.osdesc = osDesc; }
|
||||||
mesh.SendCommand(r);
|
mesh.SendCommand(r);
|
||||||
|
|
||||||
|
// Send SMBios tables if present
|
||||||
|
if (SMBiosTablesRaw != null) { mesh.SendCommand({ "action": "smbios", "value": SMBiosTablesRaw }); }
|
||||||
|
|
||||||
// Update list of logged in users
|
// Update list of logged in users
|
||||||
if (obj.loggedInUsers != null) { mesh.SendCommand({ "action": "coreinfo", "v": { "users": obj.loggedInUsers } }); }
|
if (obj.loggedInUsers != null) { mesh.SendCommand({ "action": "coreinfo", "v": { "users": obj.loggedInUsers } }); }
|
||||||
|
|
||||||
@ -1422,9 +1429,9 @@ function createMeshCore(agent) {
|
|||||||
try {
|
try {
|
||||||
amtMeiTmpState = { Flags: 0 }; // Flags: 1=EHBC, 2=CCM, 4=ACM
|
amtMeiTmpState = { Flags: 0 }; // Flags: 1=EHBC, 2=CCM, 4=ACM
|
||||||
amtMei.getProtocolVersion(function (result) { if (result != null) { amtMeiTmpState.MeiVersion = result; } });
|
amtMei.getProtocolVersion(function (result) { if (result != null) { amtMeiTmpState.MeiVersion = result; } });
|
||||||
amtMei.getVersion(function (val) { amtMeiTmpState.Versions = {}; for (var version in val.Versions) { amtMeiTmpState.Versions[val.Versions[version].Description] = val.Versions[version].Version; } });
|
amtMei.getVersion(function (result) { if (result) { amtMeiTmpState.Versions = {}; for (var version in result.Versions) { amtMeiTmpState.Versions[result.Versions[version].Description] = result.Versions[version].Version; } } });
|
||||||
amtMei.getProvisioningMode(function (result) { amtMeiTmpState.ProvisioningMode = result.mode; });
|
amtMei.getProvisioningMode(function (result) { if (result) { amtMeiTmpState.ProvisioningMode = result.mode; } });
|
||||||
amtMei.getProvisioningState(function (result) { amtMeiTmpState.ProvisioningState = result.state; });
|
amtMei.getProvisioningState(function (result) { if (result) { amtMeiTmpState.ProvisioningState = result.state; } });
|
||||||
amtMei.getEHBCState(function (result) { if ((result != null) && (result.EHBC == true)) { amtMeiTmpState.Flags += 1; } });
|
amtMei.getEHBCState(function (result) { if ((result != null) && (result.EHBC == true)) { amtMeiTmpState.Flags += 1; } });
|
||||||
amtMei.getControlMode(function (result) { if (result != null) { if (result.controlMode == 1) { amtMeiTmpState.Flags += 2; } if (result.controlMode == 2) { amtMeiTmpState.Flags += 4; } } });
|
amtMei.getControlMode(function (result) { if (result != null) { if (result.controlMode == 1) { amtMeiTmpState.Flags += 2; } if (result.controlMode == 2) { amtMeiTmpState.Flags += 4; } } });
|
||||||
amtMei.getUuid(function (result) { if ((result != null) && (result.uuid != null)) { amtMeiTmpState.UUID = result.uuid; } });
|
amtMei.getUuid(function (result) { if ((result != null) && (result.uuid != null)) { amtMeiTmpState.UUID = result.uuid; } });
|
||||||
|
8
db.js
8
db.js
@ -129,9 +129,11 @@ module.exports.CreateDB = function (parent) {
|
|||||||
obj.file.count({ type: 'user' }, function (err, userCount) {
|
obj.file.count({ type: 'user' }, function (err, userCount) {
|
||||||
obj.file.count({ type: 'ifinfo' }, function (err, nodeInterfaceCount) {
|
obj.file.count({ type: 'ifinfo' }, function (err, nodeInterfaceCount) {
|
||||||
obj.file.count({ type: 'note' }, function (err, noteCount) {
|
obj.file.count({ type: 'note' }, function (err, noteCount) {
|
||||||
obj.file.count({ type: 'lastconnect' }, function (err, nodeLastConnectCount) {
|
obj.file.count({ type: 'smbios' }, function (err, nodeSmbiosCount) {
|
||||||
obj.file.count({ }, function (err, totalCount) {
|
obj.file.count({ type: 'lastconnect' }, function (err, nodeLastConnectCount) {
|
||||||
func({ nodes: nodeCount, meshes: meshCount, powerEvents: powerCount, users: userCount, nodeInterfaces: nodeInterfaceCount, notes: noteCount, connectEvent: nodeLastConnectCount, total: totalCount });
|
obj.file.count({ }, function (err, totalCount) {
|
||||||
|
func({ nodes: nodeCount, meshes: meshCount, powerEvents: powerCount, users: userCount, nodeInterfaces: nodeInterfaceCount, notes: noteCount, connectEvent: nodeLastConnectCount, smbios: nodeSmbiosCount, total: totalCount });
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
11
meshagent.js
11
meshagent.js
@ -69,6 +69,7 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
obj.db.Remove('if' + obj.dbNodeKey); // Remove interface information
|
obj.db.Remove('if' + obj.dbNodeKey); // Remove interface information
|
||||||
obj.db.Remove('nt' + obj.dbNodeKey); // Remove notes
|
obj.db.Remove('nt' + obj.dbNodeKey); // Remove notes
|
||||||
obj.db.Remove('lc' + obj.dbNodeKey); // Remove last connect time
|
obj.db.Remove('lc' + obj.dbNodeKey); // Remove last connect time
|
||||||
|
obj.db.Remove('sm' + obj.dbNodeKey); // Remove SMBios data
|
||||||
obj.db.RemoveNode(obj.dbNodeKey); // Remove all entries with node:id
|
obj.db.RemoveNode(obj.dbNodeKey); // Remove all entries with node:id
|
||||||
|
|
||||||
// Event node deletion
|
// Event node deletion
|
||||||
@ -522,6 +523,16 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
{
|
{
|
||||||
// Sent by the agent to update agent information
|
// Sent by the agent to update agent information
|
||||||
ChangeAgentCoreInfo(command);
|
ChangeAgentCoreInfo(command);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
case 'smbios':
|
||||||
|
{
|
||||||
|
// The RAW SMBios table of this computer
|
||||||
|
obj.db.Set({ _id: 'sm' + obj.dbNodeKey, type: 'smbios', domain: domain.id, time: Date.now(), smbios: command.value });
|
||||||
|
|
||||||
|
// Event the node interface information change (This is a lot of traffic, probably don't need this).
|
||||||
|
//obj.parent.parent.DispatchEvent(['*', obj.meshid], obj, { action: 'smBiosChange', nodeid: obj.dbNodeKey, domain: domain.id, smbios: command.value, nolog: 1 });
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'netinfo':
|
case 'netinfo':
|
||||||
|
@ -131,7 +131,7 @@ module.exports.CreateMeshUser = function (parent, db, ws, req, args, domain) {
|
|||||||
if (obj.parent.parent.platform != 'win32') { stats.cpuavg = os.loadavg(); } // else { stats.cpuavg = [ 0.2435345, 0.523234234, 0.6435345345 ]; }
|
if (obj.parent.parent.platform != 'win32') { stats.cpuavg = os.loadavg(); } // else { stats.cpuavg = [ 0.2435345, 0.523234234, 0.6435345345 ]; }
|
||||||
var serverStats = { "User Accounts": Object.keys(obj.parent.users).length, "Device Groups": Object.keys(obj.parent.meshes).length, "Connected Agents": Object.keys(obj.parent.wsagents).length, "Connected Users": Object.keys(obj.parent.wssessions2).length };
|
var serverStats = { "User Accounts": Object.keys(obj.parent.users).length, "Device Groups": Object.keys(obj.parent.meshes).length, "Connected Agents": Object.keys(obj.parent.wsagents).length, "Connected Users": Object.keys(obj.parent.wssessions2).length };
|
||||||
if (obj.parent.parent.mpsserver != null) { serverStats['Connected Intel® AMT'] = Object.keys(obj.parent.parent.mpsserver.ciraConnections).length; }
|
if (obj.parent.parent.mpsserver != null) { serverStats['Connected Intel® AMT'] = Object.keys(obj.parent.parent.mpsserver.ciraConnections).length; }
|
||||||
stats.values = { "Server State": serverStats, "Database": { "Records": data.total, "Users": data.users, "Device Groups": data.meshes, "Devices": data.nodes, "Device NetInfo": data.nodeInterfaces, "Device Power Event": data.powerEvents, "Notes": data.notes, "Connection Records": data.connectEvents } }
|
stats.values = { "Server State": serverStats, "Database": { "Records": data.total, "Users": data.users, "Device Groups": data.meshes, "Devices": data.nodes, "Device NetInfo": data.nodeInterfaces, "Device Power Event": data.powerEvents, "Notes": data.notes, "Connection Records": data.connectEvents, "SMBios": data.smbios } }
|
||||||
try { ws.send(JSON.stringify(stats)); } catch (ex) { }
|
try { ws.send(JSON.stringify(stats)); } catch (ex) { }
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -865,6 +865,7 @@ module.exports.CreateMeshUser = function (parent, db, ws, req, args, domain) {
|
|||||||
obj.db.Remove('if' + node._id); // Remove interface information
|
obj.db.Remove('if' + node._id); // Remove interface information
|
||||||
obj.db.Remove('nt' + node._id); // Remove notes
|
obj.db.Remove('nt' + node._id); // Remove notes
|
||||||
obj.db.Remove('lc' + node._id); // Remove last connect time
|
obj.db.Remove('lc' + node._id); // Remove last connect time
|
||||||
|
obj.db.Remove('sm' + node._id); // Remove SMBios data
|
||||||
obj.db.RemoveNode(node._id); // Remove all entries with node:id
|
obj.db.RemoveNode(node._id); // Remove all entries with node:id
|
||||||
|
|
||||||
// Event node deletion
|
// Event node deletion
|
||||||
|
Loading…
Reference in New Issue
Block a user