mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-11 23:13:21 -05:00
Added device group change feature
This commit is contained in:
parent
4831c8aae0
commit
23973cd8ce
@ -413,7 +413,7 @@ module.exports.CreateMeshAgent = function (parent, db, ws, req, args, domain) {
|
|||||||
if (device.agent.ver != obj.agentInfo.agentVersion) { device.agent.ver = obj.agentInfo.agentVersion; change = 1; changes.push('agent version'); }
|
if (device.agent.ver != obj.agentInfo.agentVersion) { device.agent.ver = obj.agentInfo.agentVersion; change = 1; changes.push('agent version'); }
|
||||||
if (device.agent.id != obj.agentInfo.agentId) { device.agent.id = obj.agentInfo.agentId; change = 1; changes.push('agent type'); }
|
if (device.agent.id != obj.agentInfo.agentId) { device.agent.id = obj.agentInfo.agentId; change = 1; changes.push('agent type'); }
|
||||||
if ((device.agent.caps & 24) != (obj.agentInfo.capabilities & 24)) { device.agent.caps = obj.agentInfo.capabilities; change = 1; changes.push('agent capabilities'); } // If agent console or javascript support changes, update capabilities
|
if ((device.agent.caps & 24) != (obj.agentInfo.capabilities & 24)) { device.agent.caps = obj.agentInfo.capabilities; change = 1; changes.push('agent capabilities'); } // If agent console or javascript support changes, update capabilities
|
||||||
if (device.meshid != obj.dbMeshKey) { device.meshid = obj.dbMeshKey; change = 1; log = 1; changes.push('agent meshid'); } // TODO: If the meshid changes, we need to event a device add/remove on both meshes
|
if (device.meshid != obj.dbMeshKey) { obj.dbMeshKey = device.meshid; obj.meshid = device.meshid.split('/')[2]; } // If the mesh does not match, the server mesh is the correct one. This is because we allow the server to change the mesh of a device server-side.
|
||||||
if (change == 1) {
|
if (change == 1) {
|
||||||
obj.db.Set(device);
|
obj.db.Set(device);
|
||||||
|
|
||||||
|
41
meshuser.js
41
meshuser.js
@ -1068,6 +1068,47 @@ module.exports.CreateMeshUser = function (parent, db, ws, req, args, domain, use
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case 'changeDeviceMesh':
|
||||||
|
{
|
||||||
|
if (obj.common.validateString(command.nodeid, 1, 256) == false) break; // Check nodeid string
|
||||||
|
if (obj.common.validateString(command.meshid, 1, 256) == false) break; // Check meshid string
|
||||||
|
|
||||||
|
obj.db.Get(command.nodeid, function (err, nodes) {
|
||||||
|
if (nodes.length != 1) return;
|
||||||
|
var node = nodes[0];
|
||||||
|
|
||||||
|
// Check if already in the right mesh
|
||||||
|
if (node.meshid == command.meshid) return;
|
||||||
|
|
||||||
|
// Make sure that we have rights on both source and destination mesh
|
||||||
|
var sourceMeshRights = user.links[node.meshid].rights;
|
||||||
|
var targetMeshRights = user.links[command.meshid].rights;
|
||||||
|
if (((sourceMeshRights & 4) == 0) || ((targetMeshRights & 4) == 0)) return;
|
||||||
|
|
||||||
|
// Perform the switch, start by saving the node with the new meshid.
|
||||||
|
var oldMeshId = node.meshid;
|
||||||
|
node.meshid = command.meshid;
|
||||||
|
obj.db.Set(node);
|
||||||
|
|
||||||
|
// If the device is connected on this server, switch it now.
|
||||||
|
var agentSession = obj.parent.wsagents[command.nodeid];
|
||||||
|
if (agentSession != null) { agentSession.dbMeshKey = command.meshid; agentSession.meshid = command.meshid.split('/')[2]; }
|
||||||
|
|
||||||
|
// Add the connection state
|
||||||
|
var state = obj.parent.parent.GetConnectivityState(node._id);
|
||||||
|
if (state) {
|
||||||
|
node.conn = state.connectivity;
|
||||||
|
node.pwr = state.powerState;
|
||||||
|
if ((state.connectivity & 1) != 0) { var agent = obj.parent.wsagents[node._id]; if (agent != null) { node.agct = agent.connectTime; } }
|
||||||
|
if ((state.connectivity & 2) != 0) { var cira = obj.parent.parent.mpsserver.ciraConnections[node._id]; if (cira != null) { node.cict = cira.tag.connectTime; } }
|
||||||
|
}
|
||||||
|
|
||||||
|
// Event the node change
|
||||||
|
var newMesh = obj.parent.meshes[command.meshid];
|
||||||
|
obj.parent.parent.DispatchEvent(['*', oldMeshId, command.meshid], obj, { etype: 'node', username: user.name, action: 'nodemeshchange', nodeid: node._id, node: node, oldMeshId: oldMeshId, newMeshId: command.meshid, msg: 'Moved device ' + node.name + ' to group ' + newMesh.name, domain: domain.id });
|
||||||
|
});
|
||||||
|
break;
|
||||||
|
}
|
||||||
case 'removedevices':
|
case 'removedevices':
|
||||||
{
|
{
|
||||||
if (obj.common.validateArray(command.nodeids, 1) == false) break; // Check nodeid's
|
if (obj.common.validateArray(command.nodeids, 1) == false) break; // Check nodeid's
|
||||||
|
File diff suppressed because one or more lines are too long
File diff suppressed because one or more lines are too long
@ -715,7 +715,7 @@
|
|||||||
//onSearchInputChanged();
|
//onSearchInputChanged();
|
||||||
updateDevices();
|
updateDevices();
|
||||||
//refreshMap(false, true);
|
//refreshMap(false, true);
|
||||||
if (xxcurrentView == 0) { if ('{{viewmode}}' != '') { go(parseInt('{{viewmode}}')); } else { setDialogMode(0); go(1); } }
|
if (xxcurrentView == 0) { if ('{{viewmode}}' != '') { go(parseInt('{{viewmode}}')); } else { setDialogMode(0); go(2); } }
|
||||||
if ('{{currentNode}}' != '') { gotoDevice('{{currentNode}}', parseInt('{{viewmode}}')); }
|
if ('{{currentNode}}' != '') { gotoDevice('{{currentNode}}', parseInt('{{viewmode}}')); }
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -827,7 +827,7 @@
|
|||||||
nodes = newnodes;
|
nodes = newnodes;
|
||||||
|
|
||||||
// If we are looking at a node in the deleted mesh, move back to "My Devices"
|
// If we are looking at a node in the deleted mesh, move back to "My Devices"
|
||||||
if (xxcurrentView >= 10 && xxcurrentView < 20 && currentNode && currentNode.meshid == message.event.meshid) { setDialogMode(0); go(1); }
|
if (xxcurrentView >= 10 && xxcurrentView < 20 && currentNode && currentNode.meshid == message.event.meshid) { setDialogMode(0); go(2); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
updateMeshes();
|
updateMeshes();
|
||||||
@ -855,7 +855,7 @@
|
|||||||
// If we are looking at a mesh that is now deleted, move back to "My Account"
|
// If we are looking at a mesh that is now deleted, move back to "My Account"
|
||||||
if (xxcurrentView >= 20 && xxcurrentView < 30 && currentMesh._id == message.event.meshid) { setDialogMode(0); go(2); }
|
if (xxcurrentView >= 20 && xxcurrentView < 30 && currentMesh._id == message.event.meshid) { setDialogMode(0); go(2); }
|
||||||
// If we are looking at a node in the deleted mesh, move back to "My Devices"
|
// If we are looking at a node in the deleted mesh, move back to "My Devices"
|
||||||
if (xxcurrentView >= 10 && xxcurrentView < 20 && currentNode && currentNode.meshid == message.event.meshid) { setDialogMode(0); go(1); }
|
if (xxcurrentView >= 10 && xxcurrentView < 20 && currentNode && currentNode.meshid == message.event.meshid) { setDialogMode(0); go(2); }
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -881,7 +881,7 @@
|
|||||||
if (index != -1) {
|
if (index != -1) {
|
||||||
var node = nodes[index];
|
var node = nodes[index];
|
||||||
if (currentNode == node) {
|
if (currentNode == node) {
|
||||||
if (xxcurrentView >= 10 && xxcurrentView < 20) { setDialogMode(0); go(1); }
|
if (xxcurrentView >= 10 && xxcurrentView < 20) { setDialogMode(0); go(2); }
|
||||||
currentNode = null;
|
currentNode = null;
|
||||||
// TODO: Correctly disconnect from this node (Desktop/Terminal/Files...)
|
// TODO: Correctly disconnect from this node (Desktop/Terminal/Files...)
|
||||||
}
|
}
|
||||||
@ -938,6 +938,43 @@
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case 'nodemeshchange': {
|
||||||
|
var index = -1;
|
||||||
|
for (var i in nodes) { if (nodes[i]._id == message.event.nodeid) { index = i; break; } }
|
||||||
|
if (index != -1) {
|
||||||
|
var node = nodes[index];
|
||||||
|
if (meshes[message.event.newMeshId] == null) {
|
||||||
|
// We don't see the new mesh, remove this device
|
||||||
|
|
||||||
|
// TODO: Correctly disconnect from this node (Desktop/Terminal/Files...)
|
||||||
|
if (currentNode == node) { if (xxcurrentView >= 10 && xxcurrentView < 20) { setDialogMode(0); go(2); } currentNode = null; }
|
||||||
|
nodes.splice(index, 1);
|
||||||
|
} else {
|
||||||
|
// We see the new mesh, move this device
|
||||||
|
node.meshid = message.event.newMeshId;
|
||||||
|
node.meshnamel = meshes[message.event.newMeshId].name.toLowerCase();
|
||||||
|
}
|
||||||
|
updateDevices();
|
||||||
|
refreshDevice(message.event.nodeid);
|
||||||
|
} else {
|
||||||
|
// This is a new device, add it.
|
||||||
|
var node = message.event.node;
|
||||||
|
if (!meshes[node.meshid]) break; // This is a node for a mesh we don't know. Happens when we are site administrator, we get all messages.
|
||||||
|
node.namel = node.name.toLowerCase();
|
||||||
|
if (node.rname) { node.rnamel = node.rname.toLowerCase(); } else { node.rnamel = node.namel; }
|
||||||
|
node.meshnamel = meshes[node.meshid].name.toLowerCase();
|
||||||
|
node.state = 0;
|
||||||
|
if (!node.icon) node.icon = 1;
|
||||||
|
node.ident = ++nodeShortIdent;
|
||||||
|
if (nodes == null) { }
|
||||||
|
nodes.push(node);
|
||||||
|
|
||||||
|
// Web page update
|
||||||
|
//masterUpdate(1 | 2 | 4 | 16);
|
||||||
|
updateDevices();
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
case 'nodeconnect': {
|
case 'nodeconnect': {
|
||||||
// Indicated a node has changed connectivity state
|
// Indicated a node has changed connectivity state
|
||||||
var index = -1;
|
var index = -1;
|
||||||
@ -1652,9 +1689,9 @@
|
|||||||
function getCurrentNode() { return currentNode; };
|
function getCurrentNode() { return currentNode; };
|
||||||
function gotoDevice(nodeid, panel, refresh) {
|
function gotoDevice(nodeid, panel, refresh) {
|
||||||
var node = getNodeFromId(nodeid);
|
var node = getNodeFromId(nodeid);
|
||||||
if (node == null) { goBack(); }
|
if (node == null) { goBack(); return; }
|
||||||
var mesh = meshes[node.meshid];
|
var mesh = meshes[node.meshid];
|
||||||
if (mesh == null) { goBack(); }
|
if (mesh == null) { goBack(); return; }
|
||||||
var meshrights = mesh.links['user/' + domain + '/' + userinfo.name.toLowerCase()].rights;
|
var meshrights = mesh.links['user/' + domain + '/' + userinfo.name.toLowerCase()].rights;
|
||||||
if (!currentNode || currentNode._id != node._id || refresh == true) {
|
if (!currentNode || currentNode._id != node._id || refresh == true) {
|
||||||
currentNode = node;
|
currentNode = node;
|
||||||
|
@ -1680,6 +1680,43 @@
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
case 'nodemeshchange': {
|
||||||
|
var index = -1;
|
||||||
|
for (var i in nodes) { if (nodes[i]._id == message.event.nodeid) { index = i; break; } }
|
||||||
|
if (index != -1) {
|
||||||
|
var node = nodes[index];
|
||||||
|
if (meshes[message.event.newMeshId] == null) {
|
||||||
|
// We don't see the new mesh, remove this device
|
||||||
|
|
||||||
|
// TODO: Correctly disconnect from this node (Desktop/Terminal/Files...)
|
||||||
|
if (currentNode == node) { if (xxcurrentView >= 10 && xxcurrentView < 20) { setDialogMode(0); go(1); } currentNode = null; }
|
||||||
|
nodes.splice(index, 1);
|
||||||
|
masterUpdate(4 | 16);
|
||||||
|
} else {
|
||||||
|
// We see the new mesh, move this device
|
||||||
|
node.meshid = message.event.newMeshId;
|
||||||
|
node.meshnamel = meshes[message.event.newMeshId].name.toLowerCase();
|
||||||
|
masterUpdate(1 | 2 | 4);
|
||||||
|
}
|
||||||
|
refreshDevice(message.event.nodeid);
|
||||||
|
} else {
|
||||||
|
// This is a new device, add it.
|
||||||
|
var node = message.event.node;
|
||||||
|
if (!meshes[node.meshid]) break; // This is a node for a mesh we don't know. Happens when we are site administrator, we get all messages.
|
||||||
|
node.namel = node.name.toLowerCase();
|
||||||
|
if (node.rname) { node.rnamel = node.rname.toLowerCase(); } else { node.rnamel = node.namel; }
|
||||||
|
node.meshnamel = meshes[node.meshid].name.toLowerCase();
|
||||||
|
node.state = 0;
|
||||||
|
if (!node.icon) node.icon = 1;
|
||||||
|
node.ident = ++nodeShortIdent;
|
||||||
|
if (nodes == null) { }
|
||||||
|
nodes.push(node);
|
||||||
|
|
||||||
|
// Web page update
|
||||||
|
masterUpdate(1 | 2 | 4 | 16);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
case 'nodeconnect': {
|
case 'nodeconnect': {
|
||||||
// Indicated a node has changed connectivity state
|
// Indicated a node has changed connectivity state
|
||||||
var index = -1;
|
var index = -1;
|
||||||
@ -3447,7 +3484,11 @@
|
|||||||
|
|
||||||
// Show bottom buttons
|
// Show bottom buttons
|
||||||
x = '<div style=float:right;font-size:x-small>';
|
x = '<div style=float:right;font-size:x-small>';
|
||||||
if ((meshrights & 4) != 0) x += '<a style=cursor:pointer onclick=p10showDeleteNodeDialog("' + node._id + '") title="Remove this device">Delete Device</a>';
|
if ((meshrights & 4) != 0) {
|
||||||
|
// TODO: Show change group only if there is another mesh of the same type.
|
||||||
|
x += ' <a style=cursor:pointer onclick=p10showChangeGroupDialog("' + node._id + '") title="Move this device to a different device group">Change Group</a>';
|
||||||
|
x += ' <a style=cursor:pointer onclick=p10showDeleteNodeDialog("' + node._id + '") title="Remove this device">Delete Device</a>';
|
||||||
|
}
|
||||||
x += '</div><div style=font-size:x-small>';
|
x += '</div><div style=font-size:x-small>';
|
||||||
if (mesh.mtype == 2) x += '<a style=cursor:pointer onclick=p10showNodeNetInfoDialog("' + node._id + '") title="Show device network interface information">Interfaces</a> ';
|
if (mesh.mtype == 2) x += '<a style=cursor:pointer onclick=p10showNodeNetInfoDialog("' + node._id + '") title="Show device network interface information">Interfaces</a> ';
|
||||||
if (xxmap != null) x += '<a style=cursor:pointer onclick=p10showNodeLocationDialog("' + node._id + '") title="Show device locations information">Location</a> ';
|
if (xxmap != null) x += '<a style=cursor:pointer onclick=p10showNodeLocationDialog("' + node._id + '") title="Show device locations information">Location</a> ';
|
||||||
@ -3711,6 +3752,32 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function p10showChangeGroupDialog(nodeid) {
|
||||||
|
var node = getNodeFromId(nodeid);
|
||||||
|
if (xxdialogMode || (node == null)) return;
|
||||||
|
var mesh1 = meshes[node.meshid];
|
||||||
|
|
||||||
|
// List all available alternative groups
|
||||||
|
var y = "<select id=p10newGroup style=width:236px>", count = 0;
|
||||||
|
for (var i in meshes) {
|
||||||
|
var meshrights = meshes[i].links['user/' + domain + '/' + userinfo.name.toLowerCase()].rights;
|
||||||
|
if ((meshes[i]._id != mesh1._id) && (meshes[i].mtype == mesh1.mtype) && (meshrights & 4)) { count++; y += "<option value='" + meshes[i]._id + "'>" + meshes[i].name + "</option>"; }
|
||||||
|
}
|
||||||
|
y += "</select>";
|
||||||
|
|
||||||
|
if (count > 0) {
|
||||||
|
var x = "Select a new group for this device<br /><br />";
|
||||||
|
x += addHtmlValue('New Device Group', y);
|
||||||
|
setDialogMode(2, "Change Group", 3, p10showChangeGroupDialogEx, x, nodeid);
|
||||||
|
} else {
|
||||||
|
setDialogMode(2, "Change Group", 1, null, "No other device group of same type exists.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function p10showChangeGroupDialogEx(b, nodeid) {
|
||||||
|
meshserver.send({ action: 'changeDeviceMesh', nodeid: nodeid, meshid: Q('p10newGroup').value });
|
||||||
|
}
|
||||||
|
|
||||||
function p10showDeleteNodeDialog(nodeid) {
|
function p10showDeleteNodeDialog(nodeid) {
|
||||||
if (xxdialogMode) return;
|
if (xxdialogMode) return;
|
||||||
var x = "Are you sure you want to delete node \"" + EscapeHtml(currentNode.name) + "\"?<br /><br />";
|
var x = "Are you sure you want to delete node \"" + EscapeHtml(currentNode.name) + "\"?<br /><br />";
|
||||||
@ -5657,7 +5724,7 @@
|
|||||||
x += '</tbody></table>';
|
x += '</tbody></table>';
|
||||||
|
|
||||||
// If we are full administrator on this mesh, allow deletion of the mesh
|
// If we are full administrator on this mesh, allow deletion of the mesh
|
||||||
if (meshrights == 0xFFFFFFFF) { x += '<div style=font-size:x-small;text-align:right><span><a onclick=p20showDeleteMeshDialog() style=cursor:pointer>Delete Mesh</a></span></div>'; }
|
if (meshrights == 0xFFFFFFFF) { x += '<div style=font-size:x-small;text-align:right><span><a onclick=p20showDeleteMeshDialog() style=cursor:pointer>Delete Group</a></span></div>'; }
|
||||||
|
|
||||||
QH('p20info', x);
|
QH('p20info', x);
|
||||||
}
|
}
|
||||||
@ -5708,9 +5775,9 @@
|
|||||||
|
|
||||||
function p20showDeleteMeshDialog() {
|
function p20showDeleteMeshDialog() {
|
||||||
if (xxdialogMode) return;
|
if (xxdialogMode) return;
|
||||||
var x = "Are you sure you want to delete mesh \"" + EscapeHtml(currentMesh.name) + "\"? Deleting the mesh will also delete all information about computers within this mesh.<br /><br />";
|
var x = "Are you sure you want to delete group \"" + EscapeHtml(currentMesh.name) + "\"? Deleting the device group will also delete all information about devices within this group.<br /><br />";
|
||||||
x += "<input id=p20check type=checkbox onchange=p20validateDeleteMeshDialog() />Confirm";
|
x += "<input id=p20check type=checkbox onchange=p20validateDeleteMeshDialog() />Confirm";
|
||||||
setDialogMode(2, "Delete Mesh", 3, p20showDeleteMeshDialogEx, x);
|
setDialogMode(2, "Delete Group", 3, p20showDeleteMeshDialogEx, x);
|
||||||
p20validateDeleteMeshDialog();
|
p20validateDeleteMeshDialog();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user