mirror of
https://github.com/Ylianst/MeshCentral.git
synced 2025-01-14 08:14:59 -05:00
Merge branch 'master' of https://github.com/Ylianst/MeshCentral
This commit is contained in:
commit
b0b407203d
@ -24,34 +24,126 @@ var msh = {};
|
|||||||
var s = null;
|
var s = null;
|
||||||
try { s = require('service-manager').manager.getService('meshagent'); } catch (e) { }
|
try { s = require('service-manager').manager.getService('meshagent'); } catch (e) { }
|
||||||
|
|
||||||
var buttons = ["Connect", "Cancel"];
|
function _install()
|
||||||
if (s) {
|
{
|
||||||
buttons.unshift("Uninstall");
|
var mstr = require('fs').createWriteStream(process.execPath + '.msh', { flags: 'wb' });
|
||||||
buttons.unshift("Update");
|
mstr.write('MeshName=' + msh.MeshName + '\n');
|
||||||
} else {
|
mstr.write('MeshType=' + msh.MeshType + '\n');
|
||||||
buttons.unshift("Install");
|
mstr.write('MeshID=' + msh.MeshID + '\n');
|
||||||
|
mstr.write('ServerID=' + msh.ServerID + '\n');
|
||||||
|
mstr.write('MeshServer=' + msh.MeshServer + '\n');
|
||||||
|
mstr.end();
|
||||||
|
|
||||||
|
global._child = require('child_process').execFile(process.execPath,
|
||||||
|
[process.execPath.split('/').pop(), '-fullinstall', '--no-embedded=1', '--copy-msh=1']);
|
||||||
|
|
||||||
|
global._child.stdout.on('data', function (c) { process.stdout.write(c.toString()); });
|
||||||
|
global._child.stderr.on('data', function (c) { process.stdout.write(c.toString()); });
|
||||||
|
global._child.waitExit();
|
||||||
|
}
|
||||||
|
function _uninstall()
|
||||||
|
{
|
||||||
|
global._child = require('child_process').execFile(process.execPath,
|
||||||
|
[process.execPath.split('/').pop(), '-fulluninstall', '--no-embedded=1']);
|
||||||
|
|
||||||
|
global._child.stdout.on('data', function (c) { process.stdout.write(c.toString()); });
|
||||||
|
global._child.stderr.on('data', function (c) { process.stdout.write(c.toString()); });
|
||||||
|
global._child.waitExit();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((require('message-box').zenity == null) || (!require('message-box').zenity.extra)) {
|
var s = null;
|
||||||
console.log('\n' + "This installer cannot run on this system.");
|
try { s = require('service-manager').manager.getService('meshagent'); } catch (e) { }
|
||||||
console.log("Try installing/updating Zenity, and run again." + '\n');
|
var buttons = ['Cancel'];
|
||||||
process.exit();
|
|
||||||
|
if (msh.InstallFlags == null)
|
||||||
|
{
|
||||||
|
msh.InstallFlags = 3;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
msh.InstallFlags = parseInt(msh.InstallFlags.toString());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!s) {
|
|
||||||
|
if ((msh.InstallFlags & 1) == 1) { buttons.unshift("Connect"); }
|
||||||
|
if ((msh.InstallFlags & 2) == 2)
|
||||||
|
{
|
||||||
|
if (!require('user-sessions').isRoot())
|
||||||
|
{
|
||||||
|
console.log('\n' + "Elevated permissions is required to install/uninstall the agent.");
|
||||||
|
console.log("Please try again with sudo.");
|
||||||
|
process.exit();
|
||||||
|
}
|
||||||
|
if (s)
|
||||||
|
{
|
||||||
|
if (process.platform == 'darwin' || require('message-box').kdialog)
|
||||||
|
{
|
||||||
|
buttons.unshift("Setup");
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
buttons.unshift("Uninstall");
|
||||||
|
buttons.unshift("Update");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
buttons.unshift("Install");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (process.platform != 'darwin')
|
||||||
|
{
|
||||||
|
if (!require('message-box').kdialog && (require('message-box').zenity == null || (!require('message-box').zenity.extra)))
|
||||||
|
{
|
||||||
|
console.log('\n' + "This installer cannot run on this system.");
|
||||||
|
console.log("Try installing/updating Zenity, and run again." + '\n');
|
||||||
|
process.exit();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (!require('user-sessions').isRoot()) { console.log('\n' + "This utility requires elevated permissions. Please try again with sudo."); process.exit(); }
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!s)
|
||||||
|
{
|
||||||
msg = "Agent: " + "NOT INSTALLED" + '\n';
|
msg = "Agent: " + "NOT INSTALLED" + '\n';
|
||||||
} else {
|
} else
|
||||||
|
{
|
||||||
msg = "Agent: " + (s.isRunning() ? "RUNNING" : "NOT RUNNING") + '\n';
|
msg = "Agent: " + (s.isRunning() ? "RUNNING" : "NOT RUNNING") + '\n';
|
||||||
}
|
}
|
||||||
|
|
||||||
msg += ("Device Group: " + msh.MeshName + '\n');
|
msg += ("Device Group: " + msh.MeshName + '\n');
|
||||||
msg += ("Server URL: " + msh.MeshServer + '\n');
|
msg += ("Server URL: " + msh.MeshServer + '\n');
|
||||||
|
|
||||||
var p = require('message-box').create("MeshCentral Agent Setup", msg, 99999, buttons);
|
var p = require('message-box').create("MeshCentral Agent Setup", msg, 99999, buttons);
|
||||||
p.then(function (v) {
|
p.then(function (v)
|
||||||
switch (v) {
|
{
|
||||||
|
switch (v)
|
||||||
|
{
|
||||||
case "Cancel":
|
case "Cancel":
|
||||||
process.exit();
|
process.exit();
|
||||||
break;
|
break;
|
||||||
|
case "Setup":
|
||||||
|
var d = require('message-box').create("MeshCentral Agent", msg, 99999, ["Update", "Uninstall", "Cancel"]);
|
||||||
|
d.then(function (v)
|
||||||
|
{
|
||||||
|
switch (v)
|
||||||
|
{
|
||||||
|
case "Update":
|
||||||
|
case "Install":
|
||||||
|
_install();
|
||||||
|
break;
|
||||||
|
case "Uninstall":
|
||||||
|
_uninstall();
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
process.exit();
|
||||||
|
}).catch(function (v) { process.exit(); });
|
||||||
|
break;
|
||||||
case "Connect":
|
case "Connect":
|
||||||
global._child = require('child_process').execFile(process.execPath,
|
global._child = require('child_process').execFile(process.execPath,
|
||||||
[process.execPath.split('/').pop(), '--no-embedded=1', '--disableUpdate=1',
|
[process.execPath.split('/').pop(), '--no-embedded=1', '--disableUpdate=1',
|
||||||
@ -68,34 +160,24 @@ p.then(function (v) {
|
|||||||
msg = ("Device Group: " + msh.MeshName + '\n');
|
msg = ("Device Group: " + msh.MeshName + '\n');
|
||||||
msg += ("Server URL: " + msh.MeshServer + '\n');
|
msg += ("Server URL: " + msh.MeshServer + '\n');
|
||||||
|
|
||||||
|
if (process.platform != 'darwin')
|
||||||
|
{
|
||||||
|
if (!require('message-box').zenity && require('message-box').kdialog)
|
||||||
|
{
|
||||||
|
msg += ('\n'+"Press OK to Disconnect");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var d = require('message-box').create("MeshCentral Agent", msg, 99999, ["Disconnect"]);
|
var d = require('message-box').create("MeshCentral Agent", msg, 99999, ["Disconnect"]);
|
||||||
d.then(function (v) { process.exit(); }).catch(function (v) { process.exit(); });
|
d.then(function (v) { process.exit(); }).catch(function (v) { process.exit(); });
|
||||||
break;
|
break;
|
||||||
case "Uninstall":
|
case "Uninstall":
|
||||||
global._child = require('child_process').execFile(process.execPath,
|
_uninstall();
|
||||||
[process.execPath.split('/').pop(), '-fulluninstall', '--no-embedded=1']);
|
|
||||||
|
|
||||||
global._child.stdout.on('data', function (c) { process.stdout.write(c.toString()); });
|
|
||||||
global._child.stderr.on('data', function (c) { process.stdout.write(c.toString()); });
|
|
||||||
global._child.waitExit();
|
|
||||||
process.exit();
|
process.exit();
|
||||||
break;
|
break;
|
||||||
case "Install":
|
case "Install":
|
||||||
case "Update":
|
case "Update":
|
||||||
var mstr = require('fs').createWriteStream(process.execPath + '.msh', { flags: 'wb' });
|
_install();
|
||||||
mstr.write('MeshName=' + msh.MeshName + '\n');
|
|
||||||
mstr.write('MeshType=' + msh.MeshType + '\n');
|
|
||||||
mstr.write('MeshID=' + msh.MeshID + '\n');
|
|
||||||
mstr.write('ServerID=' + msh.ServerID + '\n');
|
|
||||||
mstr.write('MeshServer=' + msh.MeshServer + '\n');
|
|
||||||
mstr.end();
|
|
||||||
|
|
||||||
global._child = require('child_process').execFile(process.execPath,
|
|
||||||
[process.execPath.split('/').pop(), '-fullinstall', '--no-embedded=1', '--copy-msh=1']);
|
|
||||||
|
|
||||||
global._child.stdout.on('data', function (c) { process.stdout.write(c.toString()); });
|
|
||||||
global._child.stderr.on('data', function (c) { process.stdout.write(c.toString()); });
|
|
||||||
global._child.waitExit();
|
|
||||||
process.exit();
|
process.exit();
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
@ -103,7 +185,8 @@ p.then(function (v) {
|
|||||||
process.exit();
|
process.exit();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}).catch(function (e) {
|
}).catch(function (e)
|
||||||
|
{
|
||||||
|
console.log(e);
|
||||||
process.exit();
|
process.exit();
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in New Issue
Block a user