Browse Source

Merge pull request #154 from SuperNETorg/agama-start-fix

show message if another agama is running
all-modes
pbca26 8 years ago
committed by GitHub
parent
commit
6cdafbe795
  1. 66
      main.js
  2. 3
      routes/shepherd.js

66
main.js

@ -11,6 +11,8 @@ const electron = require('electron'),
spawn = require('child_process').spawn, spawn = require('child_process').spawn,
exec = require('child_process').exec, exec = require('child_process').exec,
{ Menu } = require('electron'), { Menu } = require('electron'),
portscanner = require('portscanner'),
osPlatform = os.platform(),
fixPath = require('fix-path'); fixPath = require('fix-path');
var express = require('express'), var express = require('express'),
@ -34,14 +36,14 @@ const appBasicInfo = {
app.setName(appBasicInfo.name); app.setName(appBasicInfo.name);
app.setVersion(appBasicInfo.version); app.setVersion(appBasicInfo.version);
if (os.platform() === 'linux') { if (osPlatform === 'linux') {
process.env.ELECTRON_RUN_AS_NODE = true; process.env.ELECTRON_RUN_AS_NODE = true;
// console.log(process.env); // console.log(process.env);
} }
// GUI APP settings and starting gui on address http://120.0.0.1:17777 // GUI APP settings and starting gui on address http://120.0.0.1:17777
var shepherd = require('./routes/shepherd'), var shepherd = require('./routes/shepherd');
guiapp = express(); var guiapp = express();
shepherd.createIguanaDirs(); shepherd.createIguanaDirs();
@ -54,7 +56,7 @@ shepherd.writeLog(`totalmem_readable: ${formatBytes(os.totalmem())}`);
shepherd.writeLog(`arch: ${os.arch()}`); shepherd.writeLog(`arch: ${os.arch()}`);
shepherd.writeLog(`cpu: ${os.cpus()[0].model}`); shepherd.writeLog(`cpu: ${os.cpus()[0].model}`);
shepherd.writeLog(`cpu_cores: ${os.cpus().length}`); shepherd.writeLog(`cpu_cores: ${os.cpus().length}`);
shepherd.writeLog(`platform: ${os.platform()}`); shepherd.writeLog(`platform: ${osPlatform}`);
shepherd.writeLog(`os_release: ${os.release()}`); shepherd.writeLog(`os_release: ${os.release()}`);
shepherd.writeLog(`os_type: ${os.type()}`); shepherd.writeLog(`os_type: ${os.type()}`);
@ -64,21 +66,25 @@ shepherd.writeLog(`app started in ${(appConfig.dev ? 'dev mode' : ' user mode')}
shepherd.setConfKMD(); shepherd.setConfKMD();
// kill rogue iguana copies on start
if (appConfig.killIguanaOnStart) { if (appConfig.killIguanaOnStart) {
let iguanaGrep; let iguanaGrep;
if (os.platform() === 'darwin') { switch (osPlatform) {
iguanaGrep = "ps -p $(ps -A | grep -m1 iguana | awk '{print $1}') | grep -i iguana"; case 'darwin':
} iguanaGrep = "ps -p $(ps -A | grep -m1 iguana | awk '{print $1}') | grep -i iguana";
if (os.platform() === 'linux') { break;
iguanaGrep = 'ps -p $(pidof iguana) | grep -i iguana'; case 'linux':
} iguanaGrep = 'ps -p $(pidof iguana) | grep -i iguana';
if (os.platform() === 'win32') { break;
iguanaGrep = 'tasklist'; case 'win32':
iguanaGrep = 'tasklist';
break;
} }
exec(iguanaGrep, function(error, stdout, stderr) { exec(iguanaGrep, function(error, stdout, stderr) {
if (stdout.indexOf('iguana') > -1) { if (stdout.indexOf('iguana') > -1) {
const pkillCmd = os.platform() === 'win32' ? 'taskkill /f /im iguana.exe' : 'pkill -15 iguana'; const pkillCmd = osPlatform === 'win32' ? 'taskkill /f /im iguana.exe' : 'pkill -15 iguana';
console.log('found another iguana process(es)'); console.log('found another iguana process(es)');
shepherd.writeLog('found another iguana process(es)'); shepherd.writeLog('found another iguana process(es)');
@ -118,7 +124,7 @@ process.once('loaded', () => {
global.setImmediate = _setImmediate; global.setImmediate = _setImmediate;
global.clearImmediate = _clearImmediate; global.clearImmediate = _clearImmediate;
if (os.platform() === 'darwin') { if (osPlatform === 'darwin') {
process.setFdLimit(appConfig.maxDescriptors.darwin); process.setFdLimit(appConfig.maxDescriptors.darwin);
app.setAboutPanelOptions({ app.setAboutPanelOptions({
applicationName: app.getName(), applicationName: app.getName(),
@ -127,7 +133,7 @@ process.once('loaded', () => {
credits: 'SuperNET Team' credits: 'SuperNET Team'
}) })
} }
if (os.platform() === 'linux') { if (osPlatform === 'linux') {
process.setFdLimit(appConfig.maxDescriptors.linux); process.setFdLimit(appConfig.maxDescriptors.linux);
} }
}); });
@ -148,10 +154,25 @@ guiapp.use('/shepherd', shepherd);
const server = require('http').createServer(guiapp); const server = require('http').createServer(guiapp);
const io = require('socket.io').listen(server); const io = require('socket.io').listen(server);
let willQuitApp = false;
server.listen(appConfig.agamaPort, function() { // check if agama is already running
console.log(`guiapp and sockets.io are listening on port ${appConfig.agamaPort}`); portscanner.checkPortStatus(appConfig.agamaPort, '127.0.0.1', function(error, status) {
shepherd.writeLog(`guiapp and sockets.io are listening on port ${appConfig.agamaPort}`); // Status is 'open' if currently in use or 'closed' if available
if (status === 'closed') {
server.listen(appConfig.agamaPort, function() {
console.log(`guiapp and sockets.io are listening on port ${appConfig.agamaPort}`);
shepherd.writeLog(`guiapp and sockets.io are listening on port ${appConfig.agamaPort}`);
});
} else {
willQuitApp = true;
server.listen(appConfig.agamaPort + 1, function() {
console.log(`guiapp and sockets.io are listening on port ${appConfig.agamaPort + 1}`);
shepherd.writeLog(`guiapp and sockets.io are listening on port ${appConfig.agamaPort + 1}`);
});
loadingWindow.loadURL(`http://${appConfig.host}:${appConfig.agamaPort + 1}/gui/agama-instance-error.html`);
console.log('another agama app is already running');
}
}); });
io.set('origins', appConfig.dev ? 'http://127.0.0.1:3000' : `http://127.0.0.1:${appConfig.agamaPort}`); // set origin io.set('origins', appConfig.dev ? 'http://127.0.0.1:3000' : `http://127.0.0.1:${appConfig.agamaPort}`); // set origin
@ -188,7 +209,6 @@ if (os.platform() === 'win32') {
let mainWindow; let mainWindow;
let loadingWindow; let loadingWindow;
let willQuitApp = false;
let closeAppAfterLoading = false; let closeAppAfterLoading = false;
function createLoadingWindow() { function createLoadingWindow() {
@ -204,6 +224,7 @@ function createLoadingWindow() {
loadingWindow.createWindow = createWindow; // expose createWindow to front-end scripts loadingWindow.createWindow = createWindow; // expose createWindow to front-end scripts
loadingWindow.appConfig = appConfig; loadingWindow.appConfig = appConfig;
loadingWindow.forseCloseApp = forseCloseApp;
// load our index.html (i.e. easyDEX GUI) // load our index.html (i.e. easyDEX GUI)
loadingWindow.loadURL(`http://${appConfig.host}:${appConfig.agamaPort}/gui/`); loadingWindow.loadURL(`http://${appConfig.host}:${appConfig.agamaPort}/gui/`);
@ -231,6 +252,13 @@ function createLoadingWindow() {
}); });
} }
// close app
function forseCloseApp() {
loadingWindow = null;
mainWindow = null;
app.quit();
}
app.on('ready', createLoadingWindow); app.on('ready', createLoadingWindow);
function createWindow (status) { function createWindow (status) {

3
routes/shepherd.js

@ -460,7 +460,6 @@ shepherd.get('/update/patch/check', function(req, res, next) {
} else { } else {
localVersion = localVersionFile.split('\n'); localVersion = localVersionFile.split('\n');
} }
console.log(localVersion);
if (remoteVersion[0] === localVersion[0]) { if (remoteVersion[0] === localVersion[0]) {
const successObj = { const successObj = {
@ -709,7 +708,7 @@ shepherd.post('/cli', function(req, res, next) {
}; };
res.end(JSON.stringify(errorObj)); res.end(JSON.stringify(errorObj));
} else if (!req.body.payload.cmd.match(/^[0-9a-zA-Z _\[\]"'/\\]+$/g)) { } else if (!req.body.payload.cmd.match(/^[0-9a-zA-Z _\,\.\[\]"'/\\]+$/g)) {
const errorObj = { const errorObj = {
'msg': 'error', 'msg': 'error',
'result': 'wrong cli string format' 'result': 'wrong cli string format'

Loading…
Cancel
Save