|
@ -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; |