Browse Source

run native only

all-modes
pbca26 8 years ago
parent
commit
81a9a87195
  1. 64
      gui/init.js
  2. 8
      main.js
  3. 117
      routes/shepherd.js

64
gui/init.js

@ -7,42 +7,46 @@ $(document).ready(function() {
animation: 'pulse' animation: 'pulse'
}); });
$('#loading_status_text').text('Starting Iguana daemon...');
GetAppConf(inititalWalletLoading); GetAppConf(inititalWalletLoading);
function inititalWalletLoading(appConf) { $('#loading_status_text').text('Starting Wallet. Please wait...');
if (appConf && !appConf.manualIguanaStart) {
StartIguana();
}
var portcheck;
function startcheck() {
portcheck = setInterval(function(){
Iguana_activehandle(appConf).then(function(result){
console.log(result);
if (result !== 'error') { function inititalWalletLoading(appConf) {
stopcheck(); // run iguana-less mode with no daemons startup
if (appConf && appConf.iguanaLessMode) {
if (appConf && appConf.useBasiliskInstance) { window.createWindow('open');
StartIguana_Cache(); window.hide();
} else { // run normal mode with 2 iguana instances started prior loading GUI
if (appConf && !appConf.manualIguanaStart) {
StartIguana();
}
var portcheck;
function startcheck() {
portcheck = setInterval(function(){
Iguana_activehandle(appConf).then(function(result){
console.log(result);
if (result !== 'error') {
stopcheck();
if (appConf && appConf.useBasiliskInstance) {
StartIguana_Cache();
}
$('#loading_status_text').text('Connecting to Basilisk Network...');
EDEX_DEXgetinfoAll(appConf.skipBasiliskNetworkCheck, appConf.minNotaries, appConf);
} }
})
}, 2000);
}
$('#loading_status_text').text('Connecting to Basilisk Network...'); function stopcheck() {
EDEX_DEXgetinfoAll(appConf.skipBasiliskNetworkCheck, appConf.minNotaries, appConf); clearInterval(portcheck);
} }
})
//var check = Iguana_activehandle();
//console.log(check[0])
}, 2000);
}
function stopcheck() { startcheck();
clearInterval(portcheck);
} }
startcheck();
} }
}); });

8
main.js

@ -196,8 +196,8 @@ function createLoadingWindow() {
// initialise window // initialise window
loadingWindow = new BrowserWindow({ loadingWindow = new BrowserWindow({
width: 500, width: appConfig.iguanaLessMode ? 1 : 500,
height: 300, height: appConfig.iguanaLessMode ? 1 : 300,
frame: false, frame: false,
icon: iguanaIcon icon: iguanaIcon
}); });
@ -307,10 +307,6 @@ function createWindow (status) {
shepherd.dumpCacheBeforeExit(); shepherd.dumpCacheBeforeExit();
shepherd.quitKomodod(); shepherd.quitKomodod();
// if komodod is under heavy load it may not respond to cli stop the first time
setInterval(function() {
shepherd.quitKomodod();
}, 100);
pm2.connect(true, function(err) { pm2.connect(true, function(err) {
console.log('connecting to pm2...'); console.log('connecting to pm2...');

117
routes/shepherd.js

@ -25,6 +25,7 @@ var ps = require('ps-node'),
assetChainPorts = require('./ports.js'), assetChainPorts = require('./ports.js'),
shepherd = express.Router(), shepherd = express.Router(),
iguanaInstanceRegistry = {}, iguanaInstanceRegistry = {},
coindInstanceRegistry = {},
syncOnlyIguanaInstanceInfo = {}, syncOnlyIguanaInstanceInfo = {},
syncOnlyInstanceInterval = -1, syncOnlyInstanceInterval = -1,
guiLog = {}, guiLog = {},
@ -97,7 +98,8 @@ shepherd.appConfig = {
"cli": { "cli": {
"passthru": false, "passthru": false,
"default": false "default": false
} },
"iguanaLessMode": false
}; };
shepherd.writeLog = function(data) { shepherd.writeLog = function(data) {
@ -273,17 +275,30 @@ shepherd.post('/coinslist', function(req, res, next) {
}); });
// TODO: check if komodod is running // TODO: check if komodod is running
shepherd.quitKomodod = function(chain) { shepherd.quitKomodod = function() {
// if komodod is under heavy load it may not respond to cli stop the first time
// exit komodod gracefully // exit komodod gracefully
console.log('exec ' + komodocliBin + (chain ? ' -ac_name=' + chain : '') + ' stop'); let coindExitInterval = {};
exec(komodocliBin + (chain ? ' -ac_name=' + chain : '') + ' stop', function(error, stdout, stderr) {
console.log(`stdout: ${stdout}`);
console.log(`stderr: ${stderr}`);
if (error !== null) { for (let key in coindInstanceRegistry) {
console.log(`exec error: ${error}`); const chain = key !== 'komodod' ? key : null;
}
}); coindExitInterval[key] = setInterval(function() {
console.log('exec ' + komodocliBin + (chain ? ' -ac_name=' + chain : '') + ' stop');
exec(komodocliBin + (chain ? ' -ac_name=' + chain : '') + ' stop', function(error, stdout, stderr) {
console.log(`stdout: ${stdout}`);
console.log(`stderr: ${stderr}`);
if (stdout.indexOf('stopping') > -1) {
clearInterval(coindExitInterval[key]);
}
if (error !== null) {
console.log(`exec error: ${error}`);
}
});
}, 100);
}
} }
shepherd.getConf = function(chain) { shepherd.getConf = function(chain) {
@ -489,7 +504,7 @@ shepherd.saveLocalAppConf = function(appSettings) {
shepherd.loadLocalConfig = function() { shepherd.loadLocalConfig = function() {
if (fs.existsSync(`${iguanaDir}/config.json`)) { if (fs.existsSync(`${iguanaDir}/config.json`)) {
let localAppConfig = fs.readFileSync(`${iguanaDir}/config.json`, 'utf8'); let localAppConfig = fs.readFileSync(`${iguanaDir}/config.json`, 'utf8');
console.log('app config set from local file'); console.log('app config set from local file');
shepherd.writeLog('app config set from local file'); shepherd.writeLog('app config set from local file');
@ -509,7 +524,7 @@ shepherd.loadLocalConfig = function() {
if (localAppConfig) { if (localAppConfig) {
const compareConfigs = compareJSON(shepherd.appConfig, JSON.parse(localAppConfig)); const compareConfigs = compareJSON(shepherd.appConfig, JSON.parse(localAppConfig));
if (Object.keys(compareConfigs).length) { if (Object.keys(compareConfigs).length) {
const newConfig = Object.assign(JSON.parse(localAppConfig), compareConfigs); const newConfig = Object.assign(JSON.parse(localAppConfig), compareConfigs);
@ -803,6 +818,56 @@ shepherd.post('/forks', function(req, res, next) {
}); });
}); });
/*
* type: GET
*
*/
shepherd.get('/InstantDEX/allcoins', function(req, res, next) {
// TODO: if only native return obj
// else query main iguana instance and return combined response
// http://localhost:7778/api/InstantDEX/allcoins?userpass=tmpIgRPCUser@1234
let successObj;
if (Object.keys(iguanaInstanceRegistry).length) {
// call to iguana
} else {
let nativeCoindList = [];
for (let key in coindInstanceRegistry) {
nativeCoindList.push(key === 'komodod' ? 'KMD' : key);
}
successObj = {
'native': nativeCoindList,
'basilisk': [],
'full': []
};
}
console.log(successObj);
res.end(JSON.stringify(successObj));
});
/*
* type: GET
*
*/
shepherd.get('/SuperNET/activehandle', function(req, res, next) {
// TODO: if only native return obj
// else query main iguana instance and return combined response
// http://localhost:7778/api/SuperNET/activehandle?userpass=tmpIgRPCUser@1234
const successObj = {
'pubkey': 'nativeonly',
'result': 'success',
'handle': '',
'status': Object.keys(coindInstanceRegistry).length ? 'unlocked' : 'locked',
'duration': 2507830
};
res.end(JSON.stringify(successObj));
});
/* /*
* type: GET * type: GET
* params: pubkey * params: pubkey
@ -1179,7 +1244,7 @@ shepherd.readDebugLog = function(fileLocation, lastNLines) {
const lines = data.trim().split('\n'); const lines = data.trim().split('\n');
const lastLine = lines.slice(lines.length - lastNLines, lines.length).join('\n'); const lastLine = lines.slice(lines.length - lastNLines, lines.length).join('\n');
resolve(lastLine); resolve(lastLine);
}); });
} }
@ -1272,7 +1337,7 @@ function herder(flock, data) {
if (flock === 'komodod') { if (flock === 'komodod') {
let kmdDebugLogLocation = (data.ac_name !== 'komodod' ? komodoDir + '/' + data.ac_name : komodoDir) + '/debug.log'; let kmdDebugLogLocation = (data.ac_name !== 'komodod' ? komodoDir + '/' + data.ac_name : komodoDir) + '/debug.log';
console.log('komodod flock selected...'); console.log('komodod flock selected...');
console.log(`selected data: ${data}`); console.log(`selected data: ${data}`);
shepherd.writeLog('komodod flock selected...'); shepherd.writeLog('komodod flock selected...');
@ -1304,11 +1369,12 @@ function herder(flock, data) {
// Status is 'open' if currently in use or 'closed' if available // Status is 'open' if currently in use or 'closed' if available
if (status === 'closed') { if (status === 'closed') {
// start komodod via exec // start komodod via exec
if (data.ac_name === 'komodod') { //if (data.ac_name === 'komodod') {
const _customParamDict = { const _customParamDict = {
'silent': '&', 'silent': '&',
'reindex': '-reindex', 'reindex': '-reindex',
'change': '-pubkey=' 'change': '-pubkey=',
'datadir': '-datadir='
}; };
let _customParam = ''; let _customParam = '';
@ -1322,7 +1388,12 @@ function herder(flock, data) {
console.log(`exec ${komododBin} ${data.ac_options.join(' ')}${_customParam}`); console.log(`exec ${komododBin} ${data.ac_options.join(' ')}${_customParam}`);
shepherd.writeLog(`exec ${komododBin} ${data.ac_options.join(' ')}${_customParam}`); shepherd.writeLog(`exec ${komododBin} ${data.ac_options.join(' ')}${_customParam}`);
exec(`${komododBin} ${data.ac_options.join(' ')}${_customParam}`, { const isChain = data.ac_name.match(/^[A-Z]*$/);
const coindACParam = isChain ? ` -ac_name=${data.ac_name} ` : '';
console.log('coindAC ' + coindACParam);
coindInstanceRegistry[data.ac_name] = true;
exec(`${komododBin} ${coindACParam}${data.ac_options.join(' ')}${_customParam}`, {
maxBuffer: 1024 * 10000 // 10 mb maxBuffer: 1024 * 10000 // 10 mb
}, function(error, stdout, stderr) { }, function(error, stdout, stderr) {
// console.log('stdout: ' + stdout); // console.log('stdout: ' + stdout);
@ -1335,7 +1406,7 @@ function herder(flock, data) {
shepherd.writeLog(`exec error: ${error}`); shepherd.writeLog(`exec error: ${error}`);
} }
}); });
} else { /*} else {
pm2.connect(true, function(err) { // start up pm2 god pm2.connect(true, function(err) { // start up pm2 god
if (err) { if (err) {
console.error(err); console.error(err);
@ -1356,7 +1427,7 @@ function herder(flock, data) {
throw err; throw err;
}); });
}); });
} }*/
} else { } else {
console.log(`port ${_port} (${data.ac_name}) is already in use`); console.log(`port ${_port} (${data.ac_name}) is already in use`);
shepherd.writeLog(`port ${_port} (${data.ac_name}) is already in use`); shepherd.writeLog(`port ${_port} (${data.ac_name}) is already in use`);
@ -1493,14 +1564,14 @@ function setConf(flock) {
switch (flock) { switch (flock) {
case 'komodod': case 'komodod':
DaemonConfPath = `${komodoDir}/komodo.conf`; DaemonConfPath = `${komodoDir}/komodo.conf`;
if (os.platform() === 'win32') { if (os.platform() === 'win32') {
DaemonConfPath = path.normalize(DaemonConfPath); DaemonConfPath = path.normalize(DaemonConfPath);
} }
break; break;
case 'zcashd': case 'zcashd':
DaemonConfPath = `${ZcashDir}/zcash.conf`; DaemonConfPath = `${ZcashDir}/zcash.conf`;
if (os.platform() === 'win32') { if (os.platform() === 'win32') {
DaemonConfPath = path.normalize(DaemonConfPath); DaemonConfPath = path.normalize(DaemonConfPath);
} }
@ -1554,7 +1625,7 @@ function setConf(flock) {
fs.readFile(DaemonConfPath, 'utf8', function(err, data) { fs.readFile(DaemonConfPath, 'utf8', function(err, data) {
if (err) { if (err) {
shepherd.writeLog(`setconf error '${err}`); shepherd.writeLog(`setconf error ${err}`);
return console.log(err); return console.log(err);
} }
@ -1777,7 +1848,7 @@ function formatBytes(bytes, decimals) {
return '0 Bytes'; return '0 Bytes';
const k = 1000, const k = 1000,
dm = decimals + 1 || 3, dm = (decimals + 1) || 3,
sizes = [ sizes = [
'Bytes', 'Bytes',
'KB', 'KB',

Loading…
Cancel
Save