|
@ -10,7 +10,8 @@ const electron = require('electron'), |
|
|
express = require('express'), |
|
|
express = require('express'), |
|
|
exec = require('child_process').exec, |
|
|
exec = require('child_process').exec, |
|
|
md5 = require('md5'), |
|
|
md5 = require('md5'), |
|
|
pm2 = require('pm2'); |
|
|
pm2 = require('pm2'), |
|
|
|
|
|
readLastLines = require('read-last-lines'); |
|
|
|
|
|
|
|
|
Promise = require('bluebird'); |
|
|
Promise = require('bluebird'); |
|
|
|
|
|
|
|
@ -56,18 +57,33 @@ if (os.platform() === 'win32') { |
|
|
iguanaConfsDirSrc = path.normalize(iguanaConfsDirSrc); |
|
|
iguanaConfsDirSrc = path.normalize(iguanaConfsDirSrc); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
console.log(iguanaDir); |
|
|
shepherd.appConfig = { |
|
|
console.log(iguanaBin); |
|
|
"edexGuiOnly": true, |
|
|
|
|
|
"iguanaGuiOnly": false, |
|
|
|
|
|
"manualIguanaStart": false, |
|
|
|
|
|
"skipBasiliskNetworkCheck": false, |
|
|
|
|
|
"host": "127.0.0.1", |
|
|
|
|
|
"iguanaAppPort": 17777, |
|
|
|
|
|
"iguanaCorePort": 7778, |
|
|
|
|
|
"maxDescriptors": { |
|
|
|
|
|
"darwin": 90000, |
|
|
|
|
|
"linux": 1000000 |
|
|
|
|
|
} |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
console.log('iguana dir: ' + iguanaDir); |
|
|
|
|
|
console.log('iguana bin: ' + iguanaBin); |
|
|
|
|
|
|
|
|
// END IGUANA FILES AND CONFIG SETTINGS
|
|
|
// END IGUANA FILES AND CONFIG SETTINGS
|
|
|
shepherd.get('/', function(req, res, next) { |
|
|
shepherd.get('/', function(req, res, next) { |
|
|
res.send('Iguana app server') |
|
|
res.send('Iguana app server'); |
|
|
}) |
|
|
}); |
|
|
|
|
|
|
|
|
shepherd.get('/appconf', function(req, res, next) { |
|
|
shepherd.get('/appconf', function(req, res, next) { |
|
|
var obj = JSON.parse(fs.readFileSync('config.json', 'utf8')); |
|
|
shepherd.readDebugLog(); |
|
|
|
|
|
var obj = shepherd.loadLocalConfig(); |
|
|
res.send(obj); |
|
|
res.send(obj); |
|
|
}) |
|
|
}); |
|
|
|
|
|
|
|
|
shepherd.post('/herd', function(req, res) { |
|
|
shepherd.post('/herd', function(req, res) { |
|
|
console.log('======= req.body ======='); |
|
|
console.log('======= req.body ======='); |
|
@ -93,7 +109,8 @@ shepherd.post('/herdlist', function(req, res) { |
|
|
pm2.describe(req.body.herdname, function(err, list) { |
|
|
pm2.describe(req.body.herdname, function(err, list) { |
|
|
pm2.disconnect(); // disconnect after getting proc info list
|
|
|
pm2.disconnect(); // disconnect after getting proc info list
|
|
|
|
|
|
|
|
|
if (err) throw err // TODO: proper error handling
|
|
|
if (err) |
|
|
|
|
|
throw err; // TODO: proper error handling
|
|
|
|
|
|
|
|
|
console.log(list[0].pm2_env.status) // print status of IGUANA proc
|
|
|
console.log(list[0].pm2_env.status) // print status of IGUANA proc
|
|
|
console.log(list[0].pid) // print pid of IGUANA proc
|
|
|
console.log(list[0].pid) // print pid of IGUANA proc
|
|
@ -130,11 +147,61 @@ shepherd.post('/getconf', function(req, res) { |
|
|
//console.log(req.body.chain);
|
|
|
//console.log(req.body.chain);
|
|
|
|
|
|
|
|
|
var confpath = getConf(req.body.chain); |
|
|
var confpath = getConf(req.body.chain); |
|
|
console.log('got conf path is:') |
|
|
console.log('got conf path is:'); |
|
|
console.log(confpath); |
|
|
console.log(confpath); |
|
|
res.end('{ "msg": "success", "result": "' + confpath + '" }'); |
|
|
res.end('{ "msg": "success", "result": "' + confpath + '" }'); |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
shepherd.loadLocalConfig = function() { |
|
|
|
|
|
if (fs.existsSync(iguanaDir + '/config.json')) { |
|
|
|
|
|
var localAppConfig = fs.readFileSync(iguanaDir + '/config.json', 'utf8'); |
|
|
|
|
|
console.log('app config set from local file'); |
|
|
|
|
|
|
|
|
|
|
|
// find diff between local and hardcoded configs
|
|
|
|
|
|
// append diff to local config
|
|
|
|
|
|
var compareJSON = function(obj1, obj2) { |
|
|
|
|
|
var result = {}; |
|
|
|
|
|
|
|
|
|
|
|
for (var i in obj1) { |
|
|
|
|
|
if (!obj2.hasOwnProperty(i)) { |
|
|
|
|
|
result[i] = obj1[i]; |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
return result; |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
var compareConfigs = compareJSON(shepherd.appConfig, JSON.parse(localAppConfig)); |
|
|
|
|
|
if (Object.keys(compareConfigs).length) { |
|
|
|
|
|
var newConfig = Object.assign(JSON.parse(localAppConfig), compareConfigs); |
|
|
|
|
|
|
|
|
|
|
|
console.log('config diff is found, updating local config'); |
|
|
|
|
|
console.log('config diff:'); |
|
|
|
|
|
console.log(compareConfigs); |
|
|
|
|
|
|
|
|
|
|
|
shepherd.saveLocalAppConf(newConfig); |
|
|
|
|
|
return newConfig; |
|
|
|
|
|
} else { |
|
|
|
|
|
return JSON.parse(localAppConfig); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
} else { |
|
|
|
|
|
console.log('local config file is not found!'); |
|
|
|
|
|
shepherd.saveLocalAppConf(shepherd.appConfig); |
|
|
|
|
|
|
|
|
|
|
|
return shepherd.appConfig; |
|
|
|
|
|
} |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
shepherd.readDebugLog = function() { |
|
|
|
|
|
console.log('reading debug.log'); |
|
|
|
|
|
console.log(komodoDir + '/debug.log'); |
|
|
|
|
|
|
|
|
|
|
|
readLastLines |
|
|
|
|
|
.read(komodoDir + '/debug.log', 50) |
|
|
|
|
|
.then((lines) => console.log(lines)); |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
function herder(flock, data) { |
|
|
function herder(flock, data) { |
|
|
//console.log(flock);
|
|
|
//console.log(flock);
|
|
|
//console.log(data);
|
|
|
//console.log(data);
|
|
@ -208,7 +275,7 @@ function herder(flock, data) { |
|
|
}, function(err, apps) { |
|
|
}, function(err, apps) { |
|
|
pm2.disconnect(); // Disconnect from PM2
|
|
|
pm2.disconnect(); // Disconnect from PM2
|
|
|
if (err) |
|
|
if (err) |
|
|
throw err |
|
|
throw err; |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
@ -255,7 +322,8 @@ function herder(flock, data) { |
|
|
cwd: iguanaDir, |
|
|
cwd: iguanaDir, |
|
|
}, function(err, apps) { |
|
|
}, function(err, apps) { |
|
|
pm2.disconnect(); // Disconnect from PM2
|
|
|
pm2.disconnect(); // Disconnect from PM2
|
|
|
if (err) throw err |
|
|
if (err) |
|
|
|
|
|
throw err; |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
@ -271,6 +339,49 @@ function slayer(flock) { |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
shepherd.saveLocalAppConf = function(appSettings) { |
|
|
|
|
|
var appConfFileName = iguanaDir + '/config.json'; |
|
|
|
|
|
|
|
|
|
|
|
var FixFilePermissions = function() { |
|
|
|
|
|
return new Promise(function(resolve, reject) { |
|
|
|
|
|
var result = 'config.json file permissions updated to Read/Write'; |
|
|
|
|
|
|
|
|
|
|
|
fsnode.chmodSync(appConfFileName, '0666'); |
|
|
|
|
|
|
|
|
|
|
|
setTimeout(function() { |
|
|
|
|
|
console.log(result); |
|
|
|
|
|
resolve(result); |
|
|
|
|
|
}, 1000); |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
var FsWrite = function() { |
|
|
|
|
|
return new Promise(function(resolve, reject) { |
|
|
|
|
|
var result = 'config.json write file is done' |
|
|
|
|
|
|
|
|
|
|
|
fs.writeFile(appConfFileName, |
|
|
|
|
|
JSON.stringify(appSettings) |
|
|
|
|
|
.replace(/,/g, ',\n') // format json in human readable form
|
|
|
|
|
|
.replace(/:/g, ': ') |
|
|
|
|
|
.replace(/{/g, '{\n') |
|
|
|
|
|
.replace(/}/g, '\n}'), 'utf8', function(err) { |
|
|
|
|
|
if (err) |
|
|
|
|
|
return console.log(err); |
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
fsnode.chmodSync(appConfFileName, '0666'); |
|
|
|
|
|
setTimeout(function() { |
|
|
|
|
|
console.log(result); |
|
|
|
|
|
console.log('app conf.json file is created successfully at: ' + iguanaConfsDir); |
|
|
|
|
|
resolve(result); |
|
|
|
|
|
}, 2000); |
|
|
|
|
|
}); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
FsWrite() |
|
|
|
|
|
.then(FixFilePermissions()); // not really required now
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
function setConf(flock) { |
|
|
function setConf(flock) { |
|
|
console.log(flock); |
|
|
console.log(flock); |
|
|
|
|
|
|
|
@ -303,7 +414,7 @@ function setConf(flock) { |
|
|
|
|
|
|
|
|
fs.ensureFile(DaemonConfPath, function(err) { |
|
|
fs.ensureFile(DaemonConfPath, function(err) { |
|
|
console.log(err); // => null
|
|
|
console.log(err); // => null
|
|
|
}) |
|
|
}); |
|
|
|
|
|
|
|
|
setTimeout(function() { |
|
|
setTimeout(function() { |
|
|
console.log(result); |
|
|
console.log(result); |
|
|