Browse Source

split shepherd.js #2

all-modes
Petr Balashov 8 years ago
parent
commit
286c5d10b7
  1. 4
      gui/loading.css
  2. 9
      private/mainmenu.js
  3. 151
      routes/cache.js
  4. 53
      routes/shepherd.js

4
gui/loading.css

@ -12,7 +12,7 @@ body {
height: 240px; height: 240px;
width: 100%; width: 100%;
position: absolute; position: absolute;
top: 0; top: -30px;
bottom: 0; bottom: 0;
left: 0; left: 0;
right: 0; right: 0;
@ -21,7 +21,7 @@ body {
.pulse-loader { .pulse-loader {
position: absolute; position: absolute;
top: 20px; top: 10px;
left: -100px; left: -100px;
margin: 80px 50px; margin: 80px 50px;
width: 400px !important; width: 400px !important;

9
private/mainmenu.js

@ -55,6 +55,15 @@ const template = [
focusedWindow.webContents.toggleDevTools(); focusedWindow.webContents.toggleDevTools();
} }
}, },
/*{
label: 'Relaunch app',
click (item, focusedWindow) {
if (focusedWindow)
app.relaunch({ args: process.argv.slice(1).concat([ '--relaunch' ]) });
app.exit(0);
}
TODO: figure out a way to restart iguana and komodod, reload gui
},*/
{ {
type: 'separator' type: 'separator'
}, },

151
routes/cache.js

@ -1,21 +1,20 @@
const fs = require('fs-extra'); const fs = require('fs-extra'),
request = require('request'),
async = require('async'),
rimraf = require('rimraf');
var cache = {}; var cache = {};
cache.setVars = function(variable, value) { cache.setVar = function(variable, value) {
cache[variable] = value; cache[variable] = value;
} }
/*
* type: GET
* params: pubkey
*/
cache.get = function(req, res, next) { cache.get = function(req, res, next) {
var pubkey = req.query.pubkey; var pubkey = req.query.pubkey;
if (pubkey) { if (pubkey) {
if (fs.existsSync(iguanaDir + '/shepherd/cache-' + pubkey + '.json')) { if (fs.existsSync(cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json')) {
fs.readFile(iguanaDir + '/shepherd/cache-' + pubkey + '.json', 'utf8', function (err, data) { fs.readFile(cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json', 'utf8', function (err, data) {
if (err) { if (err) {
var errorObj = { var errorObj = {
'msg': 'error', 'msg': 'error',
@ -58,16 +57,12 @@ cache.get = function(req, res, next) {
} }
} }
/* cache.groomGet = function(req, res, next) {
* type: GET
* params: filename
*/
/*cache.get('/groom', function(req, res, next) {
var _filename = req.query.filename; var _filename = req.query.filename;
if (_filename) { if (_filename) {
if (fs.existsSync(iguanaDir + '/shepherd/cache-' + _filename + '.json')) { if (fs.existsSync(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json')) {
fs.readFile(iguanaDir + '/shepherd/cache-' + _filename + '.json', 'utf8', function (err, data) { fs.readFile(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json', 'utf8', function (err, data) {
if (err) { if (err) {
var errorObj = { var errorObj = {
'msg': 'error', 'msg': 'error',
@ -100,18 +95,14 @@ cache.get = function(req, res, next) {
res.end(JSON.stringify(errorObj)); res.end(JSON.stringify(errorObj));
} }
}); }
/* cache.groomDelete = function(req, res, next) {
* type: DELETE
* params: filename
*/
/*shepherd.delete('/groom', function(req, res, next) {
var _filename = req.body.filename; var _filename = req.body.filename;
if (_filename) { if (_filename) {
if (fs.existsSync(iguanaDir + '/shepherd/cache-' + _filename + '.json')) { if (fs.existsSync(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json')) {
fs.unlink(iguanaDir + '/shepherd/cache-' + _filename + '.json', function(err) { fs.unlink(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json', function(err) {
if (err) { if (err) {
var errorObj = { var errorObj = {
'msg': 'error', 'msg': 'error',
@ -144,13 +135,9 @@ cache.get = function(req, res, next) {
res.end(JSON.stringify(errorObj)); res.end(JSON.stringify(errorObj));
} }
}); }
/* cache.groomPost = function(req, res) {
* type: POST
* params: filename, payload
*/
/*shepherd.post('/groom', function(req, res) {
var _filename = req.body.filename, var _filename = req.body.filename,
_payload = req.body.payload; _payload = req.body.payload;
@ -163,7 +150,7 @@ cache.get = function(req, res, next) {
res.end(JSON.stringify(errorObj)); res.end(JSON.stringify(errorObj));
} else { } else {
fs.writeFile(iguanaDir + '/shepherd/cache-' + _filename + '.json', _payload, function (err) { fs.writeFile(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json', _payload, function (err) {
if (err) { if (err) {
var errorObj = { var errorObj = {
'msg': 'error', 'msg': 'error',
@ -189,18 +176,14 @@ cache.get = function(req, res, next) {
res.end(JSON.stringify(errorObj)); res.end(JSON.stringify(errorObj));
} }
}); }
var cacheCallInProgress = false, var cacheCallInProgress = false,
cacheGlobLifetime = 300; // sec cacheGlobLifetime = 300; // sec
// TODO: reset calls' states on new /cache call start // TODO: reset calls' states on new /cache call start
/* cache.all = function(req, res, next) {
* type: GET if (req.query.pubkey && !fs.existsSync(cache.iguanaDir + '/shepherd/cache-' + req.query.pubkey + '.json')) {
* params: userpass, pubkey, skip
*/
/*shepherd.get('/cache-all', function(req, res, next) {
if (req.query.pubkey && !fs.existsSync(iguanaDir + '/shepherd/cache-' + req.query.pubkey + '.json')) {
cacheCallInProgress = false; cacheCallInProgress = false;
} }
@ -218,12 +201,12 @@ var cacheCallInProgress = false,
basilisk: {} basilisk: {}
}, },
writeCache = function() { writeCache = function() {
fs.writeFile(iguanaDir + '/shepherd/cache-' + pubkey + '.json', JSON.stringify(outObj), function(err) { fs.writeFile(cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json', JSON.stringify(outObj), function(err) {
if (err) { if (err) {
return console.log(err); return console.log(err);
} }
console.log('file ' + iguanaDir + '/shepherd/cache-' + pubkey + '.json is updated'); console.log('file ' + cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json is updated');
}); });
}, },
callStack = {}, callStack = {},
@ -236,7 +219,7 @@ var cacheCallInProgress = false,
if (total / Object.keys(callStack).length === 1) { if (total / Object.keys(callStack).length === 1) {
cacheCallInProgress = false; cacheCallInProgress = false;
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -277,7 +260,7 @@ var cacheCallInProgress = false,
if (!internalError) { if (!internalError) {
console.log('cache-all call started'); console.log('cache-all call started');
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -290,7 +273,7 @@ var cacheCallInProgress = false,
'result': 'call is initiated' 'result': 'call is initiated'
})); }));
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -303,11 +286,11 @@ var cacheCallInProgress = false,
} }
}); });
request({ request({
url: 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/InstantDEX/allcoins?userpass=' + sessionKey, url: 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/InstantDEX/allcoins?userpass=' + sessionKey,
method: 'GET' method: 'GET'
}, function (error, response, body) { }, function (error, response, body) {
if (response && response.statusCode && response.statusCode === 200) { if (response && response.statusCode && response.statusCode === 200) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -332,7 +315,7 @@ var cacheCallInProgress = false,
outObj.basilisk[coin] = {}; outObj.basilisk[coin] = {};
writeCache(); writeCache();
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -346,11 +329,11 @@ var cacheCallInProgress = false,
} }
}); });
request({ request({
url: 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/bitcoinrpc/getaddressesbyaccount?userpass=' + sessionKey + '&coin=' + coin + '&account=*', url: 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/bitcoinrpc/getaddressesbyaccount?userpass=' + sessionKey + '&coin=' + coin + '&account=*',
method: 'GET' method: 'GET'
}, function (error, response, body) { }, function (error, response, body) {
if (response && response.statusCode && response.statusCode === 200) { if (response && response.statusCode && response.statusCode === 200) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -372,10 +355,10 @@ var cacheCallInProgress = false,
async.each(outObj.basilisk[coin].addresses, function(address) { async.each(outObj.basilisk[coin].addresses, function(address) {
var dexUrls = { var dexUrls = {
'listunspent': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/dex/listunspent?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address, 'listunspent': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/dex/listunspent?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address,
'listtransactions': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/dex/listtransactions?userpass=' + sessionKey + '&count=100&skip=0&symbol=' + coin + '&address=' + address, 'listtransactions': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/dex/listtransactions?userpass=' + sessionKey + '&count=100&skip=0&symbol=' + coin + '&address=' + address,
'getbalance': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/dex/getbalance?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address, 'getbalance': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/dex/getbalance?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address,
'refresh': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/basilisk/refresh?userpass=' + sessionKey + '&timeout=600000&symbol=' + coin + '&address=' + address 'refresh': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/basilisk/refresh?userpass=' + sessionKey + '&timeout=600000&symbol=' + coin + '&address=' + address
}; };
if (coin === 'BTC' || coin === 'SYS') { if (coin === 'BTC' || coin === 'SYS') {
delete dexUrls.refresh; delete dexUrls.refresh;
@ -404,7 +387,7 @@ var cacheCallInProgress = false,
checkTimestamp(outObj.basilisk[coin][address][key].timestamp) < cacheGlobLifetime) { checkTimestamp(outObj.basilisk[coin][address][key].timestamp) < cacheGlobLifetime) {
tooEarly = true; tooEarly = true;
outObj.basilisk[coin][address][key].status = 'done'; outObj.basilisk[coin][address][key].status = 'done';
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -422,7 +405,7 @@ var cacheCallInProgress = false,
} }
tooEarly = skipTimeout ? false : tooEarly; tooEarly = skipTimeout ? false : tooEarly;
if (!tooEarly) { if (!tooEarly) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -442,7 +425,7 @@ var cacheCallInProgress = false,
method: 'GET' method: 'GET'
}, function (error, response, body) { }, function (error, response, body) {
if (response && response.statusCode && response.statusCode === 200) { if (response && response.statusCode && response.statusCode === 200) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -491,7 +474,7 @@ var cacheCallInProgress = false,
} }
}); });
} else { } else {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -508,14 +491,14 @@ var cacheCallInProgress = false,
'result': 'another call is in progress already' 'result': 'another call is in progress already'
})); }));
} }
}); }
/* /*
* type: GET * type: GET
* params: userpass, pubkey, coin, address, skip * params: userpass, pubkey, coin, address, skip
*/ */
/*shepherd.get('/cache-one', function(req, res, next) { cache.one = function(req, res, next) {
if (req.query.pubkey && !fs.existsSync(iguanaDir + '/shepherd/cache-' + req.query.pubkey + '.json')) { if (req.query.pubkey && !fs.existsSync(cache.iguanaDir + '/shepherd/cache-' + req.query.pubkey + '.json')) {
cacheCallInProgress = false; cacheCallInProgress = false;
} }
@ -539,14 +522,14 @@ var cacheCallInProgress = false,
outObj.timestamp = timeStamp; outObj.timestamp = timeStamp;
} }
fs.writeFile(iguanaDir + '/shepherd/cache-' + pubkey + '.json', JSON.stringify(outObj), function(err) { fs.writeFile(cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json', JSON.stringify(outObj), function(err) {
if (err) { if (err) {
return console.log(err); return console.log(err);
} }
console.log('file ' + iguanaDir + '/shepherd/cache-' + pubkey + '.json is updated'); console.log('file ' + cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json is updated');
if (timeStamp) { if (timeStamp) {
console.log('file ' + iguanaDir + '/shepherd/cache-' + pubkey + '.json is timestamped'); console.log('file ' + cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json is timestamped');
} }
}); });
}, },
@ -560,7 +543,7 @@ var cacheCallInProgress = false,
if (total / Object.keys(callStack).length === 1) { if (total / Object.keys(callStack).length === 1) {
cacheCallInProgress = false; cacheCallInProgress = false;
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -606,8 +589,8 @@ var cacheCallInProgress = false,
console.log('cache-one call started'); console.log('cache-one call started');
if (fs.existsSync(iguanaDir + '/shepherd/cache-' + pubkey + '.json')) { if (fs.existsSync(cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json')) {
var _file = fs.readFileSync(iguanaDir + '/shepherd/cache-' + pubkey + '.json', 'utf8'); var _file = fs.readFileSync(cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json', 'utf8');
outObj = _file ? JSON.parse(_file) : {}; outObj = _file ? JSON.parse(_file) : {};
if (!outObj || !outObj.basilisk) { if (!outObj || !outObj.basilisk) {
@ -631,7 +614,7 @@ var cacheCallInProgress = false,
})); }));
if (!internalError) { if (!internalError) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -641,7 +624,7 @@ var cacheCallInProgress = false,
}); });
// update all available coin addresses // update all available coin addresses
if (!address) { if (!address) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -655,11 +638,11 @@ var cacheCallInProgress = false,
} }
}); });
request({ request({
url: 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/bitcoinrpc/getaddressesbyaccount?userpass=' + sessionKey + '&coin=' + coin + '&account=*', url: 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/bitcoinrpc/getaddressesbyaccount?userpass=' + sessionKey + '&coin=' + coin + '&account=*',
method: 'GET' method: 'GET'
}, function (error, response, body) { }, function (error, response, body) {
if (response && response.statusCode && response.statusCode === 200) { if (response && response.statusCode && response.statusCode === 200) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -682,10 +665,10 @@ var cacheCallInProgress = false,
async.each(outObj.basilisk[coin].addresses, function(address) { async.each(outObj.basilisk[coin].addresses, function(address) {
var dexUrls = { var dexUrls = {
'listunspent': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/dex/listunspent?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address, 'listunspent': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/dex/listunspent?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address,
'listtransactions': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/dex/listtransactions?userpass=' + sessionKey + '&count=100&skip=0&symbol=' + coin + '&address=' + address, 'listtransactions': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/dex/listtransactions?userpass=' + sessionKey + '&count=100&skip=0&symbol=' + coin + '&address=' + address,
'getbalance': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/dex/getbalance?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address, 'getbalance': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/dex/getbalance?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address,
'refresh': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/basilisk/refresh?userpass=' + sessionKey + '&timeout=600000&symbol=' + coin + '&address=' + address 'refresh': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/basilisk/refresh?userpass=' + sessionKey + '&timeout=600000&symbol=' + coin + '&address=' + address
}, },
_dexUrls = {}; _dexUrls = {};
@ -721,7 +704,7 @@ var cacheCallInProgress = false,
checkTimestamp(outObj.basilisk[coin][address][key].timestamp) < cacheGlobLifetime) { checkTimestamp(outObj.basilisk[coin][address][key].timestamp) < cacheGlobLifetime) {
tooEarly = true; tooEarly = true;
outObj.basilisk[coin][address][key].status = 'done'; outObj.basilisk[coin][address][key].status = 'done';
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -739,7 +722,7 @@ var cacheCallInProgress = false,
} }
tooEarly = skipTimeout ? false : tooEarly; tooEarly = skipTimeout ? false : tooEarly;
if (!tooEarly) { if (!tooEarly) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -759,7 +742,7 @@ var cacheCallInProgress = false,
method: 'GET' method: 'GET'
}, function (error, response, body) { }, function (error, response, body) {
if (response && response.statusCode && response.statusCode === 200) { if (response && response.statusCode && response.statusCode === 200) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -804,10 +787,10 @@ var cacheCallInProgress = false,
console.log(coin + ' stack len ' + callStack[coin]); console.log(coin + ' stack len ' + callStack[coin]);
var dexUrls = { var dexUrls = {
'listunspent': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/dex/listunspent?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address, 'listunspent': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/dex/listunspent?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address,
'listtransactions': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/dex/listtransactions?userpass=' + sessionKey + '&count=100&skip=0&symbol=' + coin + '&address=' + address, 'listtransactions': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/dex/listtransactions?userpass=' + sessionKey + '&count=100&skip=0&symbol=' + coin + '&address=' + address,
'getbalance': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/dex/getbalance?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address, 'getbalance': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/dex/getbalance?userpass=' + sessionKey + '&symbol=' + coin + '&address=' + address,
'refresh': 'http://' + shepherd.appConfig.host + ':' + shepherd.appConfig.iguanaCorePort + '/api/basilisk/refresh?userpass=' + sessionKey + '&timeout=600000&symbol=' + coin + '&address=' + address 'refresh': 'http://' + cache.appConfig.host + ':' + cache.appConfig.iguanaCorePort + '/api/basilisk/refresh?userpass=' + sessionKey + '&timeout=600000&symbol=' + coin + '&address=' + address
}, },
_dexUrls = {}; _dexUrls = {};
@ -844,7 +827,7 @@ var cacheCallInProgress = false,
checkTimestamp(outObj.basilisk[coin][address][key].timestamp) < cacheGlobLifetime) { checkTimestamp(outObj.basilisk[coin][address][key].timestamp) < cacheGlobLifetime) {
tooEarly = true; tooEarly = true;
outObj.basilisk[coin][address][key].status = 'done'; outObj.basilisk[coin][address][key].status = 'done';
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -861,7 +844,7 @@ var cacheCallInProgress = false,
}); });
} }
if (!tooEarly) { if (!tooEarly) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -881,7 +864,7 @@ var cacheCallInProgress = false,
method: 'GET' method: 'GET'
}, function (error, response, body) { }, function (error, response, body) {
if (response && response.statusCode && response.statusCode === 200) { if (response && response.statusCode && response.statusCode === 200) {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-one', 'method': 'cache-one',
@ -918,7 +901,7 @@ var cacheCallInProgress = false,
}); });
} }
} else { } else {
shepherd.io.emit('messages', { cache.io.emit('messages', {
'message': { 'message': {
'shepherd': { 'shepherd': {
'method': 'cache-all', 'method': 'cache-all',
@ -935,6 +918,6 @@ var cacheCallInProgress = false,
'result': 'another call is in progress already' 'result': 'another call is in progress already'
})); }));
} }
});*/ };
module.exports = cache; module.exports = cache;

53
routes/shepherd.js

@ -72,8 +72,6 @@ if (os.platform() === 'win32') {
komodoDir = path.normalize(komodoDir); komodoDir = path.normalize(komodoDir);
} }
shepherd.iguanaDir = iguanaDir;
shepherd.appConfig = { shepherd.appConfig = {
"edexGuiOnly": true, "edexGuiOnly": true,
"iguanaGuiOnly": false, "iguanaGuiOnly": false,
@ -110,18 +108,65 @@ shepherd.get('/sysinfo', function(req, res, next) {
res.send(obj); res.send(obj);
}); });
var cache = require('./cache');
// expose sockets obj // expose sockets obj
shepherd.setIO = function(io) { shepherd.setIO = function(io) {
shepherd.io = io; shepherd.io = io;
cache.setVar('io', io);
}; };
var cache = require('./cache');
cache.setVar('iguanaDir', iguanaDir); cache.setVar('iguanaDir', iguanaDir);
cache.setVar('appConfig', appConfig); cache.setVar('appConfig', shepherd.appConfig);
/*
* type: GET
* params: pubkey
*/
shepherd.get('/cache', function(req, res, next) { shepherd.get('/cache', function(req, res, next) {
cache.get(req, res, next); cache.get(req, res, next);
}); });
/*
* type: GET
* params: filename
*/
shepherd.get('/groom', function(req, res, next) {
cache.groomGet(req, res, next);
})
/*
* type: DELETE
* params: filename
*/
shepherd.delete('/groom', function(req, res, next) {
cache.groomDelete(req, res, next);
});
/*
* type: POST
* params: filename, payload
*/
shepherd.post('/groom', function(req, res) {
cache.groomPost(req, res, next);
});
/*
* type: GET
* params: userpass, pubkey, skip
*/
shepherd.get('/cache-all', function(req, res, next) {
cache.all(req, res, next);
});
/*
* type: GET
* params: userpass, pubkey, coin, address, skip
*/
shepherd.get('/cache-one', function(req, res, next) {
cache.one(req, res, next);
});
/* /*
* type: GET * type: GET
* params: herd, lastLines * params: herd, lastLines

Loading…
Cancel
Save