|
@ -1,6 +1,6 @@ |
|
|
const fs = require('fs-extra'), |
|
|
const fs = require('fs-extra'); |
|
|
request = require('request'), |
|
|
const request = require('request'); |
|
|
async = require('async'); |
|
|
const async = require('async'); |
|
|
|
|
|
|
|
|
var cache = {}; |
|
|
var cache = {}; |
|
|
var inMemCache; |
|
|
var inMemCache; |
|
@ -33,18 +33,18 @@ cache.get = function(req, res, next) { |
|
|
fs.readFile(`${cache.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) { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': err |
|
|
result: err, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} else { |
|
|
} else { // deprecated
|
|
|
try { |
|
|
try { |
|
|
const parsedJSON = JSON.parse(data), |
|
|
const parsedJSON = JSON.parse(data); |
|
|
successObj = { |
|
|
const successObj = { |
|
|
'msg': 'success', |
|
|
msg: 'success', |
|
|
'result': parsedJSON |
|
|
result: parsedJSON, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
inMemCache = parsedJSON; |
|
|
inMemCache = parsedJSON; |
|
|
res.end(JSON.stringify(successObj)); |
|
|
res.end(JSON.stringify(successObj)); |
|
@ -59,8 +59,8 @@ cache.get = function(req, res, next) { |
|
|
|
|
|
|
|
|
fs.writeFile(`${cache.iguanaDir}/shepherd/cache-${pubkey}.json`, data.substring(0, errorPos[errorPos.length - 1]), function(err) { |
|
|
fs.writeFile(`${cache.iguanaDir}/shepherd/cache-${pubkey}.json`, data.substring(0, errorPos[errorPos.length - 1]), function(err) { |
|
|
const successObj = { |
|
|
const successObj = { |
|
|
'msg': 'success', |
|
|
msg: 'success', |
|
|
'result': data.substring(0, errorPos[errorPos.length - 1]) |
|
|
result: data.substring(0, errorPos[errorPos.length - 1]), |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
inMemCache = JSON.parse(data.substring(0, errorPos[errorPos.length - 1])); |
|
|
inMemCache = JSON.parse(data.substring(0, errorPos[errorPos.length - 1])); |
|
@ -72,24 +72,24 @@ cache.get = function(req, res, next) { |
|
|
}); |
|
|
}); |
|
|
} else { |
|
|
} else { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': `no file with handle ${pubkey}` |
|
|
result: `no file with handle ${pubkey}`, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
const successObj = { |
|
|
const successObj = { |
|
|
'msg': 'success', |
|
|
msg: 'success', |
|
|
'result': inMemCache |
|
|
result: inMemCache, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(successObj)); |
|
|
res.end(JSON.stringify(successObj)); |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'no pubkey provided' |
|
|
result: 'no pubkey provided', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
@ -104,15 +104,15 @@ cache.groomGet = function(req, res, next) { |
|
|
fs.readFile(`${cache.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) { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': err |
|
|
result: err, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} else { |
|
|
} else { |
|
|
const successObj = { |
|
|
const successObj = { |
|
|
'msg': 'success', |
|
|
msg: 'success', |
|
|
'result': data ? JSON.parse(data) : '' |
|
|
result: data ? JSON.parse(data) : '', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(successObj)); |
|
|
res.end(JSON.stringify(successObj)); |
|
@ -120,16 +120,16 @@ cache.groomGet = function(req, res, next) { |
|
|
}); |
|
|
}); |
|
|
} else { |
|
|
} else { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': `no file with name ${_filename}` |
|
|
result: `no file with name ${_filename}`, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'no file name provided' |
|
|
result: 'no file name provided', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
@ -146,15 +146,15 @@ cache.groomDelete = function(req, res, next) { |
|
|
fs.unlink(`${cache.iguanaDir}/shepherd/cache-${_filename}.json`, function(err) { |
|
|
fs.unlink(`${cache.iguanaDir}/shepherd/cache-${_filename}.json`, function(err) { |
|
|
if (err) { |
|
|
if (err) { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': err |
|
|
result: err, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} else { |
|
|
} else { |
|
|
const successObj = { |
|
|
const successObj = { |
|
|
'msg': 'success', |
|
|
msg: 'success', |
|
|
'result': 'deleted' |
|
|
result: 'deleted', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(successObj)); |
|
|
res.end(JSON.stringify(successObj)); |
|
@ -162,16 +162,16 @@ cache.groomDelete = function(req, res, next) { |
|
|
}); |
|
|
}); |
|
|
} else { |
|
|
} else { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': `no file with name ${_filename}` |
|
|
result: `no file with name ${_filename}`, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'no file name provided' |
|
|
result: 'no file name provided', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
@ -179,8 +179,8 @@ cache.groomDelete = function(req, res, next) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
cache.groomPost = function(req, res) { |
|
|
cache.groomPost = function(req, res) { |
|
|
const _filename = req.body.filename, |
|
|
const _filename = req.body.filename; |
|
|
_payload = req.body.payload; |
|
|
const _payload = req.body.payload; |
|
|
|
|
|
|
|
|
if (!cacheCallInProgress) { |
|
|
if (!cacheCallInProgress) { |
|
|
cacheCallInProgress = true; |
|
|
cacheCallInProgress = true; |
|
@ -188,8 +188,8 @@ cache.groomPost = function(req, res) { |
|
|
if (_filename) { |
|
|
if (_filename) { |
|
|
if (!_payload) { |
|
|
if (!_payload) { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'no payload provided' |
|
|
result: 'no payload provided', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
@ -201,16 +201,16 @@ cache.groomPost = function(req, res) { |
|
|
fs.writeFile(`${cache.iguanaDir}/shepherd/cache-${_filename}.json`, _payload, function (err) { |
|
|
fs.writeFile(`${cache.iguanaDir}/shepherd/cache-${_filename}.json`, _payload, function (err) { |
|
|
if (err) { |
|
|
if (err) { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': err |
|
|
result: err, |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
cacheCallInProgress = false; |
|
|
cacheCallInProgress = false; |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} else { |
|
|
} else { |
|
|
const successObj = { |
|
|
const successObj = { |
|
|
'msg': 'success', |
|
|
msg: 'success', |
|
|
'result': 'done' |
|
|
result: 'done', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
cacheCallInProgress = false; |
|
|
cacheCallInProgress = false; |
|
@ -220,33 +220,33 @@ cache.groomPost = function(req, res) { |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'no file name provided' |
|
|
result: 'no file name provided', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'another job is in progress' |
|
|
result: 'another job is in progress', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
var cacheCallInProgress = false, |
|
|
var cacheCallInProgress = false; |
|
|
cacheGlobLifetime = 600; // sec
|
|
|
const cacheGlobLifetime = 600; // sec
|
|
|
|
|
|
|
|
|
// TODO: reset calls' states on new /cache call start
|
|
|
// TODO: reset calls' states on new /cache call start
|
|
|
var mock = require('./mock'); |
|
|
var mock = require('./mock'); |
|
|
|
|
|
|
|
|
var callStack = {}, |
|
|
var callStack = {}; |
|
|
checkCallStack = function() { |
|
|
const checkCallStack = function() { |
|
|
var total = 0; |
|
|
let total = 0; |
|
|
|
|
|
|
|
|
for (var coin in callStack) { |
|
|
for (let coin in callStack) { |
|
|
total =+ callStack[coin]; |
|
|
total =+ callStack[coin]; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -254,13 +254,13 @@ checkCallStack = function() { |
|
|
cache.dumpCacheBeforeExit(); |
|
|
cache.dumpCacheBeforeExit(); |
|
|
cacheCallInProgress = false; |
|
|
cacheCallInProgress = false; |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'done', |
|
|
status: 'done', |
|
|
'resp': 'success' |
|
|
resp: 'success', |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|
}; |
|
|
}; |
|
@ -284,45 +284,45 @@ cache.one = function(req, res, next) { |
|
|
|
|
|
|
|
|
if (fs.existsSync(`${cache.iguanaDir}/shepherd/cache-${req.query.pubkey}.json`)) { |
|
|
if (fs.existsSync(`${cache.iguanaDir}/shepherd/cache-${req.query.pubkey}.json`)) { |
|
|
let _data = fs.readFileSync(`${cache.iguanaDir}/shepherd/cache-${req.query.pubkey}.json`, 'utf8'); |
|
|
let _data = fs.readFileSync(`${cache.iguanaDir}/shepherd/cache-${req.query.pubkey}.json`, 'utf8'); |
|
|
|
|
|
|
|
|
if (_data) { |
|
|
if (_data) { |
|
|
inMemCache = JSON.parse(_data); |
|
|
inMemCache = JSON.parse(_data); |
|
|
_data = _data.replace('waiting', 'failed'); |
|
|
_data = _data.replace('waiting', 'failed'); |
|
|
cache.dumpCacheBeforeExit(); |
|
|
cache.dumpCacheBeforeExit(); |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
// TODO: add check to allow only one cache call/sequence in progress
|
|
|
// TODO: add check to allow only one cache call/sequence in progress
|
|
|
cacheCallInProgress = true; |
|
|
cacheCallInProgress = true; |
|
|
|
|
|
|
|
|
var sessionKey = req.query.userpass, |
|
|
let sessionKey = req.query.userpass; |
|
|
coin = req.query.coin, |
|
|
let coin = req.query.coin; |
|
|
address = req.query.address, |
|
|
let address = req.query.address; |
|
|
addresses = req.query.addresses && req.query.addresses.indexOf(':') > -1 ? req.query.addresses.split(':') : null, |
|
|
let addresses = req.query.addresses && req.query.addresses.indexOf(':') > -1 ? req.query.addresses.split(':') : null; |
|
|
pubkey = req.query.pubkey, |
|
|
let pubkey = req.query.pubkey; |
|
|
mock = req.query.mock, |
|
|
let mock = req.query.mock; |
|
|
skipTimeout = req.query.skip, |
|
|
let skipTimeout = req.query.skip; |
|
|
callsArray = req.query.calls.split(':'), |
|
|
let callsArray = req.query.calls.split(':'); |
|
|
iguanaCorePort = req.query.port ? req.query.port : cache.appConfig.iguanaCorePort, |
|
|
let iguanaCorePort = req.query.port ? req.query.port : cache.appConfig.iguanaCorePort; |
|
|
errorObj = { |
|
|
let errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'error' |
|
|
result: 'error', |
|
|
}, |
|
|
}; |
|
|
outObj = {}, |
|
|
let outObj = {}; |
|
|
pubkey, |
|
|
const writeCache = function(timeStamp) { |
|
|
writeCache = function(timeStamp) { |
|
|
if (timeStamp) { |
|
|
if (timeStamp) { |
|
|
outObj.timestamp = timeStamp; |
|
|
outObj.timestamp = timeStamp; |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
inMemCache = outObj; |
|
|
inMemCache = outObj; |
|
|
}, |
|
|
}; |
|
|
checkTimestamp = function(dateToCheck) { |
|
|
const checkTimestamp = function(dateToCheck) { |
|
|
var currentEpochTime = new Date(Date.now()) / 1000, |
|
|
const currentEpochTime = new Date(Date.now()) / 1000; |
|
|
secondsElapsed = Number(currentEpochTime) - Number(dateToCheck / 1000); |
|
|
const secondsElapsed = Number(currentEpochTime) - Number(dateToCheck / 1000); |
|
|
|
|
|
|
|
|
return Math.floor(secondsElapsed); |
|
|
return Math.floor(secondsElapsed); |
|
|
}, |
|
|
}; |
|
|
internalError = false; |
|
|
let internalError = false; |
|
|
|
|
|
|
|
|
inMemPubkey = pubkey; |
|
|
inMemPubkey = pubkey; |
|
|
callStack[coin] = 1; |
|
|
callStack[coin] = 1; |
|
@ -331,8 +331,8 @@ cache.one = function(req, res, next) { |
|
|
|
|
|
|
|
|
if (!sessionKey) { |
|
|
if (!sessionKey) { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'no session key provided' |
|
|
result: 'no session key provided', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
@ -341,8 +341,8 @@ cache.one = function(req, res, next) { |
|
|
|
|
|
|
|
|
if (!pubkey) { |
|
|
if (!pubkey) { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'no pubkey provided' |
|
|
result: 'no pubkey provided', |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
@ -352,7 +352,8 @@ cache.one = function(req, res, next) { |
|
|
console.log('cache-one call started'); |
|
|
console.log('cache-one call started'); |
|
|
|
|
|
|
|
|
function fixJSON(data) { |
|
|
function fixJSON(data) { |
|
|
if (data && data.length) { |
|
|
if (data && |
|
|
|
|
|
data.length) { |
|
|
try { |
|
|
try { |
|
|
const parsedJSON = JSON.parse(data); |
|
|
const parsedJSON = JSON.parse(data); |
|
|
|
|
|
|
|
@ -375,12 +376,14 @@ cache.one = function(req, res, next) { |
|
|
} |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
if (fs.existsSync(`${cache.iguanaDir}/shepherd/cache-${pubkey}.json`) && coin !== 'all') { |
|
|
if (fs.existsSync(`${cache.iguanaDir}/shepherd/cache-${pubkey}.json`) && |
|
|
|
|
|
coin !== 'all') { |
|
|
if (inMemCache) { |
|
|
if (inMemCache) { |
|
|
console.log('cache one from mem'); |
|
|
console.log('cache one from mem'); |
|
|
outObj = inMemCache; |
|
|
outObj = inMemCache; |
|
|
} else { |
|
|
} else { |
|
|
const _file = fs.readFileSync(`${cache.iguanaDir}/shepherd/cache-${pubkey}.json`, 'utf8'); |
|
|
const _file = fs.readFileSync(`${cache.iguanaDir}/shepherd/cache-${pubkey}.json`, 'utf8'); |
|
|
|
|
|
|
|
|
console.log('cache one from disk'); |
|
|
console.log('cache one from disk'); |
|
|
outObj = fixJSON(_file); |
|
|
outObj = fixJSON(_file); |
|
|
} |
|
|
} |
|
@ -402,28 +405,28 @@ cache.one = function(req, res, next) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
res.end(JSON.stringify({ |
|
|
res.end(JSON.stringify({ |
|
|
'msg': 'success', |
|
|
msg: 'success', |
|
|
'result': 'call is initiated' |
|
|
result: 'call is initiated', |
|
|
})); |
|
|
})); |
|
|
|
|
|
|
|
|
if (!internalError) { |
|
|
if (!internalError) { |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress' |
|
|
status: 'in progress', |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
function execDEXRequests(coin, address) { |
|
|
function execDEXRequests(coin, address) { |
|
|
let dexUrls = { |
|
|
let dexUrls = { |
|
|
'listunspent': `http://${cache.appConfig.host}:${iguanaCorePort}/api/dex/listunspent?userpass=${sessionKey}&symbol=${coin}&address=${address}`, |
|
|
listunspent: `http://${cache.appConfig.host}:${iguanaCorePort}/api/dex/listunspent?userpass=${sessionKey}&symbol=${coin}&address=${address}`, |
|
|
'listtransactions': `http://${cache.appConfig.host}:${iguanaCorePort}/api/dex/listtransactions?userpass=${sessionKey}&count=100&skip=0&symbol=${coin}&address=${address}`, |
|
|
listtransactions: `http://${cache.appConfig.host}:${iguanaCorePort}/api/dex/listtransactions?userpass=${sessionKey}&count=100&skip=0&symbol=${coin}&address=${address}`, |
|
|
'getbalance': `http://${cache.appConfig.host}:${iguanaCorePort}/api/dex/getbalance?userpass=${sessionKey}&symbol=${coin}&address=${address}`, |
|
|
getbalance: `http://${cache.appConfig.host}:${iguanaCorePort}/api/dex/getbalance?userpass=${sessionKey}&symbol=${coin}&address=${address}`, |
|
|
'refresh': `http://${cache.appConfig.host}:${iguanaCorePort}/api/basilisk/refresh?userpass=${sessionKey}&symbol=${coin}&address=${address}` |
|
|
refresh: `http://${cache.appConfig.host}:${iguanaCorePort}/api/basilisk/refresh?userpass=${sessionKey}&symbol=${coin}&address=${address}` |
|
|
}, |
|
|
}; |
|
|
_dexUrls = {}; |
|
|
let _dexUrls = {}; |
|
|
|
|
|
|
|
|
for (let a = 0; a < callsArray.length; a++) { |
|
|
for (let a = 0; a < callsArray.length; a++) { |
|
|
_dexUrls[callsArray[a]] = dexUrls[callsArray[a]]; |
|
|
_dexUrls[callsArray[a]] = dexUrls[callsArray[a]]; |
|
@ -455,41 +458,42 @@ cache.one = function(req, res, next) { |
|
|
|
|
|
|
|
|
async.forEachOf(_dexUrls, function(dexUrl, key) { |
|
|
async.forEachOf(_dexUrls, function(dexUrl, key) { |
|
|
var tooEarly = false; |
|
|
var tooEarly = false; |
|
|
|
|
|
|
|
|
if (outObj.basilisk[coin][address][key] && |
|
|
if (outObj.basilisk[coin][address][key] && |
|
|
outObj.basilisk[coin][address][key].timestamp && |
|
|
outObj.basilisk[coin][address][key].timestamp && |
|
|
(!skipTimeout && checkTimestamp(outObj.basilisk[coin][address][key].timestamp) < cacheGlobLifetime)) { |
|
|
(!skipTimeout && 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'; |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'method': key, |
|
|
method: key, |
|
|
'coin': coin, |
|
|
coin: coin, |
|
|
'address': address, |
|
|
address: address, |
|
|
'status': 'done', |
|
|
status: 'done', |
|
|
'resp': 'too early' |
|
|
resp: 'too early', |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|
if (!tooEarly) { |
|
|
if (!tooEarly) { |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'method': key, |
|
|
method: key, |
|
|
'coin': coin, |
|
|
coin: coin, |
|
|
'address': address, |
|
|
address: address, |
|
|
'status': 'in progress' |
|
|
status: 'in progress', |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
outObj.basilisk[coin][address][key].status = 'in progress'; |
|
|
outObj.basilisk[coin][address][key].status = 'in progress'; |
|
|
request({ |
|
|
request({ |
|
@ -500,25 +504,25 @@ cache.one = function(req, res, next) { |
|
|
response.statusCode && |
|
|
response.statusCode && |
|
|
response.statusCode === 200) { |
|
|
response.statusCode === 200) { |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'method': key, |
|
|
method: key, |
|
|
'coin': coin, |
|
|
coin: coin, |
|
|
'address': address, |
|
|
address: address, |
|
|
'status': 'done', |
|
|
status: 'done', |
|
|
'resp': body |
|
|
resp: body, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
// basilisk balance fallback
|
|
|
// basilisk balance fallback
|
|
|
const _parsedJSON = JSON.parse(body); |
|
|
const _parsedJSON = JSON.parse(body); |
|
|
if (key === 'getbalance' && |
|
|
if (key === 'getbalance' && |
|
|
coin === 'KMD'/* && |
|
|
coin === 'KMD'/* && |
|
|
((_parsedJSON && _parsedJSON.balance === 0) || body === [])*/) { |
|
|
((_parsedJSON && _parsedJSON.balance === 0) || body === [])*/) { |
|
|
console.log('fallback to kmd explorer ======>'); |
|
|
console.log('fallback to kmd explorer ======>'); |
|
|
request({ |
|
|
request({ |
|
@ -559,15 +563,15 @@ cache.one = function(req, res, next) { |
|
|
callStack[coin]--; |
|
|
callStack[coin]--; |
|
|
console.log(`${coin} _stack len ${callStack[coin]}`); |
|
|
console.log(`${coin} _stack len ${callStack[coin]}`); |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'currentStackLength': callStack[coin] |
|
|
currentStackLength: callStack[coin], |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
checkCallStack(); |
|
|
checkCallStack(); |
|
|
|
|
|
|
|
@ -583,15 +587,15 @@ cache.one = function(req, res, next) { |
|
|
callStack[coin]--; |
|
|
callStack[coin]--; |
|
|
console.log(`${coin} _stack len ${callStack[coin]}`); |
|
|
console.log(`${coin} _stack len ${callStack[coin]}`); |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'currentStackLength': callStack[coin] |
|
|
currentStackLength: callStack[coin], |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
checkCallStack(); |
|
|
checkCallStack(); |
|
|
writeCache(); |
|
|
writeCache(); |
|
@ -602,15 +606,15 @@ cache.one = function(req, res, next) { |
|
|
callStack[coin]--; |
|
|
callStack[coin]--; |
|
|
console.log(`${coin} _stack len ${callStack[coin]}`); |
|
|
console.log(`${coin} _stack len ${callStack[coin]}`); |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'currentStackLength': callStack[coin] |
|
|
currentStackLength: callStack[coin], |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
checkCallStack(); |
|
|
checkCallStack(); |
|
|
} |
|
|
} |
|
@ -619,18 +623,18 @@ cache.one = function(req, res, next) { |
|
|
|
|
|
|
|
|
function parseAddresses(coin, addrArray) { |
|
|
function parseAddresses(coin, addrArray) { |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'method': 'getaddressesbyaccount', |
|
|
method: 'getaddressesbyaccount', |
|
|
'coin': coin, |
|
|
coin: coin, |
|
|
'status': 'done', |
|
|
status: 'done', |
|
|
'resp': addrArray |
|
|
resp: addrArray, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
outObj.basilisk[coin].addresses = addrArray; |
|
|
outObj.basilisk[coin].addresses = addrArray; |
|
|
console.log(addrArray); |
|
|
console.log(addrArray); |
|
@ -649,15 +653,15 @@ cache.one = function(req, res, next) { |
|
|
console.log(`${coin} stack len ${callStack[coin]}`); |
|
|
console.log(`${coin} stack len ${callStack[coin]}`); |
|
|
|
|
|
|
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'totalStackLength': callStack[coin] |
|
|
totalStackLength: callStack[coin], |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
async.each(outObj.basilisk[coin].addresses, function(address) { |
|
|
async.each(outObj.basilisk[coin].addresses, function(address) { |
|
|
execDEXRequests(coin, address); |
|
|
execDEXRequests(coin, address); |
|
@ -687,17 +691,17 @@ cache.one = function(req, res, next) { |
|
|
// update all available coin addresses
|
|
|
// update all available coin addresses
|
|
|
if (!address) { |
|
|
if (!address) { |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'method': 'getaddressesbyaccount', |
|
|
method: 'getaddressesbyaccount', |
|
|
'coin': coin, |
|
|
coin: coin, |
|
|
'status': 'in progress' |
|
|
status: 'in progress', |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
if (coin === 'all') { |
|
|
if (coin === 'all') { |
|
@ -711,17 +715,17 @@ cache.one = function(req, res, next) { |
|
|
response.statusCode === 200) { |
|
|
response.statusCode === 200) { |
|
|
console.log(JSON.parse(body).basilisk); |
|
|
console.log(JSON.parse(body).basilisk); |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'method': 'allcoins', |
|
|
method: 'allcoins', |
|
|
'status': 'done', |
|
|
status: 'done', |
|
|
'resp': body |
|
|
resp: body, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
body = JSON.parse(body); |
|
|
body = JSON.parse(body); |
|
|
// basilisk coins
|
|
|
// basilisk coins
|
|
@ -737,17 +741,17 @@ cache.one = function(req, res, next) { |
|
|
writeCache(); |
|
|
writeCache(); |
|
|
|
|
|
|
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'method': 'getaddressesbyaccount', |
|
|
method: 'getaddressesbyaccount', |
|
|
'coin': coin, |
|
|
coin: coin, |
|
|
'status': 'in progress' |
|
|
status: 'in progress', |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
getAddresses(coin); |
|
|
getAddresses(coin); |
|
@ -776,36 +780,36 @@ cache.one = function(req, res, next) { |
|
|
console.log(`${coin} stack len ${callStack[coin]}`); |
|
|
console.log(`${coin} stack len ${callStack[coin]}`); |
|
|
|
|
|
|
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-one', |
|
|
method: 'cache-one', |
|
|
'status': 'in progress', |
|
|
status: 'in progress', |
|
|
'iguanaAPI': { |
|
|
iguanaAPI: { |
|
|
'totalStackLength': callStack[coin], |
|
|
totalStackLength: callStack[coin], |
|
|
'currentStackLength': callStack[coin] |
|
|
currentStackLength: callStack[coin], |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
execDEXRequests(coin, address); |
|
|
execDEXRequests(coin, address); |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
cache.io.emit('messages', { |
|
|
cache.io.emit('messages', { |
|
|
'message': { |
|
|
message: { |
|
|
'shepherd': { |
|
|
shepherd: { |
|
|
'method': 'cache-all', |
|
|
method: 'cache-all', |
|
|
'status': 'done', |
|
|
status: 'done', |
|
|
'resp': 'internal error' |
|
|
resp: 'internal error', |
|
|
} |
|
|
}, |
|
|
} |
|
|
}, |
|
|
}); |
|
|
}); |
|
|
cacheCallInProgress = false; |
|
|
cacheCallInProgress = false; |
|
|
} |
|
|
} |
|
|
} else { |
|
|
} else { |
|
|
res.end(JSON.stringify({ |
|
|
res.end(JSON.stringify({ |
|
|
'msg': 'error', |
|
|
msg: 'error', |
|
|
'result': 'another call is in progress already' |
|
|
result: 'another call is in progress already', |
|
|
})); |
|
|
})); |
|
|
} |
|
|
} |
|
|
}; |
|
|
}; |
|
|