mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-15 08:44:59 -05:00
Added support for agent help requests.
This commit is contained in:
parent
4be3da6136
commit
9358d610f2
@ -138,7 +138,7 @@ function createMeshCore(agent) {
|
|||||||
obj.DAIPC = require('net').createServer();
|
obj.DAIPC = require('net').createServer();
|
||||||
if (process.platform != 'win32') { try { require('fs').unlinkSync(process.cwd() + '/DAIPC'); } catch (e) { } }
|
if (process.platform != 'win32') { try { require('fs').unlinkSync(process.cwd() + '/DAIPC'); } catch (e) { } }
|
||||||
obj.DAIPC.IPCPATH = process.platform == 'win32' ? ('\\\\.\\pipe\\' + require('_agentNodeId')() + '-DAIPC') : (process.cwd() + '/DAIPC');
|
obj.DAIPC.IPCPATH = process.platform == 'win32' ? ('\\\\.\\pipe\\' + require('_agentNodeId')() + '-DAIPC') : (process.cwd() + '/DAIPC');
|
||||||
try { obj.DAIPC.listen({ path: obj.DAIPC.IPCPATH }); } catch (e) { }
|
try { obj.DAIPC.listen({ path: obj.DAIPC.IPCPATH, writableAll: true }); } catch (e) { }
|
||||||
obj.DAIPC.on('connection', function (c) {
|
obj.DAIPC.on('connection', function (c) {
|
||||||
c._send = function (j) {
|
c._send = function (j) {
|
||||||
var data = JSON.stringify(j);
|
var data = JSON.stringify(j);
|
||||||
@ -166,6 +166,19 @@ function createMeshCore(agent) {
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
switch (data.cmd) {
|
switch (data.cmd) {
|
||||||
|
case 'requesthelp':
|
||||||
|
if (this._registered == null) return;
|
||||||
|
sendConsoleText('Request Help (' + this._registered + '): ' + data.value);
|
||||||
|
var help = {};
|
||||||
|
help[this._registered] = data.value;
|
||||||
|
try { mesh.SendCommand({ action: 'sessions', type: 'help', value: help }); } catch (e) { }
|
||||||
|
MeshServerLogEx(98, [this._registered, data.value], "Help Requested, user: " + this._registered + ", details: " + data.value, null);
|
||||||
|
break;
|
||||||
|
case 'cancelhelp':
|
||||||
|
if (this._registered == null) return;
|
||||||
|
sendConsoleText('Cancel Help (' + this._registered + ')');
|
||||||
|
try { mesh.SendCommand({ action: 'sessions', type: 'help', value: {} }); } catch (e) { }
|
||||||
|
break;
|
||||||
case 'register':
|
case 'register':
|
||||||
if (typeof data.value == 'string') {
|
if (typeof data.value == 'string') {
|
||||||
this._registered = data.value;
|
this._registered = data.value;
|
||||||
|
@ -1382,6 +1382,7 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
if (command.type == 'kvm') { obj.sessions.kvm = command.value; }
|
if (command.type == 'kvm') { obj.sessions.kvm = command.value; }
|
||||||
else if (command.type == 'terminal') { obj.sessions.terminal = command.value; }
|
else if (command.type == 'terminal') { obj.sessions.terminal = command.value; }
|
||||||
else if (command.type == 'files') { obj.sessions.files = command.value; }
|
else if (command.type == 'files') { obj.sessions.files = command.value; }
|
||||||
|
else if (command.type == 'help') { obj.sessions.help = command.value; }
|
||||||
else if (command.type == 'tcp') { obj.sessions.tcp = command.value; }
|
else if (command.type == 'tcp') { obj.sessions.tcp = command.value; }
|
||||||
else if (command.type == 'udp') { obj.sessions.udp = command.value; }
|
else if (command.type == 'udp') { obj.sessions.udp = command.value; }
|
||||||
else if (command.type == 'msg') { obj.sessions.msg = command.value; }
|
else if (command.type == 'msg') { obj.sessions.msg = command.value; }
|
||||||
|
BIN
public/images/icon-help-notify-10.png
Normal file
BIN
public/images/icon-help-notify-10.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 281 B |
BIN
public/images/icon-help-notify-16.png
Normal file
BIN
public/images/icon-help-notify-16.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 420 B |
BIN
public/images/icon-help-notify-40.png
Normal file
BIN
public/images/icon-help-notify-40.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 796 B |
File diff suppressed because it is too large
Load Diff
@ -570,6 +570,7 @@
|
|||||||
<img id="p10deviceStar" class=deviceNotifyLargeDotSub src=images/icon-star-notify-40.png width=35 height=35>
|
<img id="p10deviceStar" class=deviceNotifyLargeDotSub src=images/icon-star-notify-40.png width=35 height=35>
|
||||||
<div id="p10deviceMsg" onclick=showDeviceMessages(null,null,event) class=deviceNotifyLargeDotSub></div>
|
<div id="p10deviceMsg" onclick=showDeviceMessages(null,null,event) class=deviceNotifyLargeDotSub></div>
|
||||||
<img id="p10deviceNotify" onclick=showDeviceSessions() class=deviceNotifyLargeDotSub src=images/icon-relay-notify-40.png width=35 height=35>
|
<img id="p10deviceNotify" onclick=showDeviceSessions() class=deviceNotifyLargeDotSub src=images/icon-relay-notify-40.png width=35 height=35>
|
||||||
|
<img id="p10deviceHelp" onclick=showDeviceHelpRequests(null,null,event) class=deviceNotifyLargeDotSub src=images/icon-help-notify-40.png width=35 height=35>
|
||||||
</div>
|
</div>
|
||||||
<div id="p10deviceBattery" class="deviceBatteryLarge deviceBatteryLarge1"></div>
|
<div id="p10deviceBattery" class="deviceBatteryLarge deviceBatteryLarge1"></div>
|
||||||
<div id=p10html style="margin-left:8px;margin-right:8px"></div>
|
<div id=p10html style="margin-left:8px;margin-right:8px"></div>
|
||||||
@ -1488,6 +1489,8 @@
|
|||||||
|
|
||||||
// If we are looking at the sessions dialog box for this device now, update it
|
// If we are looking at the sessions dialog box for this device now, update it
|
||||||
//if (xxdialogTag == ('SESSIONS-' + message.event.nodeid)) { showDeviceSessions(message.event.nodeid, true); }
|
//if (xxdialogTag == ('SESSIONS-' + message.event.nodeid)) { showDeviceSessions(message.event.nodeid, true); }
|
||||||
|
//if (xxdialogTag == ('MESSAGES-' + message.event.nodeid)) { showDeviceMessages(message.event.nodeid, true); }
|
||||||
|
if (xxdialogTag == ('HELPREQ-' + message.event.nodeid)) { showDeviceHelpRequests(message.event.nodeid, true); }
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -2319,6 +2322,11 @@
|
|||||||
devNotifySub += '<img class=deviceNotifyDotSub src=images/icon-relay-notify.png width=16 height=16>';
|
devNotifySub += '<img class=deviceNotifyDotSub src=images/icon-relay-notify.png width=16 height=16>';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Help is required
|
||||||
|
if (node.sessions.help != null) {
|
||||||
|
devNotifySub += '<img class=deviceNotifyDotSub src=images/icon-help-notify-16.png width=16 height=16>';
|
||||||
|
}
|
||||||
|
|
||||||
// Battery state
|
// Battery state
|
||||||
if (node.sessions.battery != null) {
|
if (node.sessions.battery != null) {
|
||||||
var bat = node.sessions.battery;
|
var bat = node.sessions.battery;
|
||||||
@ -2353,6 +2361,18 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Show device help requests
|
||||||
|
function showDeviceHelpRequests(nodeid, force, e) {
|
||||||
|
if (e) haltEvent(e);
|
||||||
|
if (xxdialogMode && !force) return false;
|
||||||
|
var node = null, x = '';
|
||||||
|
if (nodeid == null) { node = currentNode; } else { node = getNodeFromId(nodeid); }
|
||||||
|
if ((node == null) || (node.sessions == null)) { setDialogMode(0); return false; }
|
||||||
|
if (node.sessions.help != null) { for (var j in node.sessions.help) { x += '<div style=margin-bottom:6px><b>' + EscapeHtml(j) + '</b></div><div style=margin-bottom:6px>' + EscapeHtml(node.sessions.help[j]) + '</div>'; } }
|
||||||
|
if (x != '') { setDialogMode(2, "Help Requests" + ' - ' + EscapeHtml(node.name), 1, null, x, 'HELPREQ-' + node._id); } else { setDialogMode(0); }
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Show currently active sessions on this device
|
// Show currently active sessions on this device
|
||||||
function showDeviceSessions() {
|
function showDeviceSessions() {
|
||||||
if (xxdialogMode || (currentNode == null)) return;
|
if (xxdialogMode || (currentNode == null)) return;
|
||||||
@ -2485,6 +2505,7 @@
|
|||||||
// Setup session notification
|
// Setup session notification
|
||||||
QV('p10deviceNotify', (currentNode.sessions != null) && ((node.sessions.kvm != null) || (node.sessions.terminal != null) || (node.sessions.files != null) || (node.sessions.tcp != null) || (node.sessions.udp != null)));
|
QV('p10deviceNotify', (currentNode.sessions != null) && ((node.sessions.kvm != null) || (node.sessions.terminal != null) || (node.sessions.files != null) || (node.sessions.tcp != null) || (node.sessions.udp != null)));
|
||||||
QV('p10deviceStar', stars[currentNode._id] == 1);
|
QV('p10deviceStar', stars[currentNode._id] == 1);
|
||||||
|
QV('p10deviceHelp', (currentNode.sessions != null) && (currentNode.sessions.help != null))
|
||||||
if ((currentNode.sessions != null) && (currentNode.sessions.msg != null)) { QV('p10deviceMsg', true); QH('p10deviceMsg', Object.keys(currentNode.sessions.msg).length); } else { QV('p10deviceMsg', false); }
|
if ((currentNode.sessions != null) && (currentNode.sessions.msg != null)) { QV('p10deviceMsg', true); QH('p10deviceMsg', Object.keys(currentNode.sessions.msg).length); } else { QV('p10deviceMsg', false); }
|
||||||
|
|
||||||
// Device Battery
|
// Device Battery
|
||||||
|
@ -244,6 +244,7 @@
|
|||||||
<option value=2>Sessions</option>
|
<option value=2>Sessions</option>
|
||||||
<option value=3>Starred</option>
|
<option value=3>Starred</option>
|
||||||
<option value=4>Intel® AMT</option>
|
<option value=4>Intel® AMT</option>
|
||||||
|
<option value=6>Help</option>
|
||||||
</select>
|
</select>
|
||||||
<label><input type=checkbox id=RealNameCheckBox onclick=onRealNameCheckBox() /><span title="Show devices operating system name">OS Name</span></label>
|
<label><input type=checkbox id=RealNameCheckBox onclick=onRealNameCheckBox() /><span title="Show devices operating system name">OS Name</span></label>
|
||||||
<label style="display:none"><input type=checkbox id=OnlineCheckBox onclick=onOnlineCheckBox(event) /><span title="Only show devices that are online">Online</span></label>
|
<label style="display:none"><input type=checkbox id=OnlineCheckBox onclick=onOnlineCheckBox(event) /><span title="Only show devices that are online">Online</span></label>
|
||||||
@ -511,6 +512,7 @@
|
|||||||
<div id="p10deviceMsg" onclick=showDeviceMessages(null,null,event) class=deviceNotifyDotSub></div>
|
<div id="p10deviceMsg" onclick=showDeviceMessages(null,null,event) class=deviceNotifyDotSub></div>
|
||||||
<img id="p10deviceStar" class=deviceNotifyDotSub src=images/icon-star-notify-16.png width=16 height=16>
|
<img id="p10deviceStar" class=deviceNotifyDotSub src=images/icon-star-notify-16.png width=16 height=16>
|
||||||
<img id="p10deviceNotify" onclick=showDeviceSessions(null,null,event) class=deviceNotifyDotSub src=images/icon-relay-notify.png width=16 height=16>
|
<img id="p10deviceNotify" onclick=showDeviceSessions(null,null,event) class=deviceNotifyDotSub src=images/icon-relay-notify.png width=16 height=16>
|
||||||
|
<img id="p10deviceHelp" onclick=showDeviceHelpRequests(null,null,event) class=deviceNotifyDotSub src=images/icon-help-notify-16.png width=16 height=16>
|
||||||
</div>
|
</div>
|
||||||
<div id="p10deviceBattery" class="deviceBatteryLarge deviceBatteryLarge1"></div>
|
<div id="p10deviceBattery" class="deviceBatteryLarge deviceBatteryLarge1"></div>
|
||||||
<a href=# onclick=p10showiconselector()><img id=MainComputerImage></a>
|
<a href=# onclick=p10showiconselector()><img id=MainComputerImage></a>
|
||||||
@ -2496,7 +2498,18 @@
|
|||||||
mainUpdate(32);
|
mainUpdate(32);
|
||||||
}
|
}
|
||||||
if (message.event.noact) break; // Take no action on this event
|
if (message.event.noact) break; // Take no action on this event
|
||||||
|
|
||||||
switch (message.event.action) {
|
switch (message.event.action) {
|
||||||
|
case 'agentlog': {
|
||||||
|
if (message.event.msgid == 98) {
|
||||||
|
// This is a agent help request, popup a notification.
|
||||||
|
if (GetNodeRights(message.event.nodeid) > 0) {
|
||||||
|
var n = getNodeFromId(message.event.nodeid);
|
||||||
|
addNotification({ text: format("Help requested from {0}: {1}", message.event.msgArgs[0], message.event.msgArgs[1]), title: n.name, icon: n.icon, nodeid: message.event.nodeid });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
case 'recording': {
|
case 'recording': {
|
||||||
if (p52recordings != null) { p52recordings.unshift(message.event); message.event.present = 1; updateRecordings(); }
|
if (p52recordings != null) { p52recordings.unshift(message.event); message.event.present = 1; updateRecordings(); }
|
||||||
break;
|
break;
|
||||||
@ -2953,9 +2966,10 @@
|
|||||||
// If we are looking at the sessions dialog box for this device now, update it
|
// If we are looking at the sessions dialog box for this device now, update it
|
||||||
if (xxdialogTag == ('SESSIONS-' + message.event.nodeid)) { showDeviceSessions(message.event.nodeid, true); }
|
if (xxdialogTag == ('SESSIONS-' + message.event.nodeid)) { showDeviceSessions(message.event.nodeid, true); }
|
||||||
if (xxdialogTag == ('MESSAGES-' + message.event.nodeid)) { showDeviceMessages(message.event.nodeid, true); }
|
if (xxdialogTag == ('MESSAGES-' + message.event.nodeid)) { showDeviceMessages(message.event.nodeid, true); }
|
||||||
|
if (xxdialogTag == ('HELPREQ-' + message.event.nodeid)) { showDeviceHelpRequests(message.event.nodeid, true); }
|
||||||
|
|
||||||
// If we are filtering on sessions, update the visible devices
|
// If we are filtering on sessions or help, update the visible devices
|
||||||
if (Q('DevFilterSelect').value == 2) { mainUpdate(1); }
|
if ((Q('DevFilterSelect').value == 2) || (Q('DevFilterSelect').value == 6)) { mainUpdate(1); }
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'stopped': { // Server is stopping.
|
case 'stopped': { // Server is stopping.
|
||||||
@ -3459,6 +3473,15 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Help is required
|
||||||
|
if (node.sessions.help != null) {
|
||||||
|
if (view == 2) {
|
||||||
|
devNotifySub += '<img onclick=showDeviceHelpRequests(\'' + node._id + '\',null,event) class=deviceNotifySmallDotSub src=images/icon-help-notify-10.png width=10 height=10>';
|
||||||
|
} else {
|
||||||
|
devNotifySub += '<img onclick=showDeviceHelpRequests(\'' + node._id + '\',null,event) class=deviceNotifyDotSub src=images/icon-help-notify-16.png width=16 height=16>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Battery state
|
// Battery state
|
||||||
if ((node.sessions.battery != null) && (view == 1)) {
|
if ((node.sessions.battery != null) && (view == 1)) {
|
||||||
var bat = node.sessions.battery;
|
var bat = node.sessions.battery;
|
||||||
@ -3732,6 +3755,18 @@
|
|||||||
oldviewmode = view;
|
oldviewmode = view;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Show device help requests
|
||||||
|
function showDeviceHelpRequests(nodeid, force, e) {
|
||||||
|
if (e) haltEvent(e);
|
||||||
|
if (xxdialogMode && !force) return false;
|
||||||
|
var node = null, x = '';
|
||||||
|
if (nodeid == null) { node = currentNode; } else { node = getNodeFromId(nodeid); }
|
||||||
|
if ((node == null) || (node.sessions == null)) { setDialogMode(0); return false; }
|
||||||
|
if (node.sessions.help != null) { for (var j in node.sessions.help) { x += '<div style=margin-bottom:6px><b>' + EscapeHtml(j) + '</b></div><div style=margin-bottom:6px>' + EscapeHtml(node.sessions.help[j]) + '</div>'; } }
|
||||||
|
if (x != '') { setDialogMode(2, "Help Requests" + ' - ' + EscapeHtml(node.name), 1, null, x, 'HELPREQ-' + node._id); } else { setDialogMode(0); }
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
// Show currently active sessions on this device
|
// Show currently active sessions on this device
|
||||||
function showDeviceSessions(nodeid, force, e) {
|
function showDeviceSessions(nodeid, force, e) {
|
||||||
if (e) haltEvent(e);
|
if (e) haltEvent(e);
|
||||||
@ -4634,6 +4669,7 @@
|
|||||||
if (devFilter == 3) { for (var d in nodes) { if (stars[nodes[d]._id] != 1) { nodes[d].v = false; } } } // Starred
|
if (devFilter == 3) { for (var d in nodes) { if (stars[nodes[d]._id] != 1) { nodes[d].v = false; } } } // Starred
|
||||||
if (devFilter == 4) { for (var d in nodes) { if (nodes[d].intelamt == null) { nodes[d].v = false; } } } // Intel AMT
|
if (devFilter == 4) { for (var d in nodes) { if (nodes[d].intelamt == null) { nodes[d].v = false; } } } // Intel AMT
|
||||||
if (devFilter == 5) { for (var d in nodes) { if ((nodes[d].conn != null) && (nodes[d].conn != 0)) { nodes[d].v = false; } } } // Offline
|
if (devFilter == 5) { for (var d in nodes) { if ((nodes[d].conn != null) && (nodes[d].conn != 0)) { nodes[d].v = false; } } } // Offline
|
||||||
|
if (devFilter == 6) { for (var d in nodes) { var n = nodes[d]; if ((n.sessions == null) || (n.sessions.help == null)) { n.v = false; } } } // Sessions
|
||||||
}
|
}
|
||||||
|
|
||||||
var contextelement = null;
|
var contextelement = null;
|
||||||
@ -5498,6 +5534,7 @@
|
|||||||
// Device Notification
|
// Device Notification
|
||||||
QV('p10deviceNotify', (currentNode.sessions != null) && ((currentNode.sessions.kvm != null) || (currentNode.sessions.terminal != null) || (currentNode.sessions.files != null) || (currentNode.sessions.tcp != null) || (currentNode.sessions.udp != null)));
|
QV('p10deviceNotify', (currentNode.sessions != null) && ((currentNode.sessions.kvm != null) || (currentNode.sessions.terminal != null) || (currentNode.sessions.files != null) || (currentNode.sessions.tcp != null) || (currentNode.sessions.udp != null)));
|
||||||
QV('p10deviceStar', stars[currentNode._id] == 1);
|
QV('p10deviceStar', stars[currentNode._id] == 1);
|
||||||
|
QV('p10deviceHelp', (currentNode.sessions != null) && (currentNode.sessions.help != null))
|
||||||
if ((currentNode.sessions != null) && (currentNode.sessions.msg != null)) { QV('p10deviceMsg', true); QH('p10deviceMsg', Object.keys(currentNode.sessions.msg).length); } else { QV('p10deviceMsg', false); }
|
if ((currentNode.sessions != null) && (currentNode.sessions.msg != null)) { QV('p10deviceMsg', true); QH('p10deviceMsg', Object.keys(currentNode.sessions.msg).length); } else { QV('p10deviceMsg', false); }
|
||||||
|
|
||||||
// Device Battery
|
// Device Battery
|
||||||
@ -10699,7 +10736,8 @@
|
|||||||
94: "Removed security key",
|
94: "Removed security key",
|
||||||
95: "Added security key",
|
95: "Added security key",
|
||||||
96: "Verified phone number of user {0}",
|
96: "Verified phone number of user {0}",
|
||||||
97: "Removed phone number of user {0}"
|
97: "Removed phone number of user {0}",
|
||||||
|
98: "Help Requested, user: {0}, details: {1}"
|
||||||
};
|
};
|
||||||
|
|
||||||
// Highlights the device being hovered
|
// Highlights the device being hovered
|
||||||
|
Loading…
x
Reference in New Issue
Block a user