|
@ -141,7 +141,7 @@ cache.groomDelete = function(req, res, next) { |
|
|
|
|
|
|
|
|
if (_filename) { |
|
|
if (_filename) { |
|
|
if (fs.existsSync(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json')) { |
|
|
if (fs.existsSync(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json')) { |
|
|
inMemCache = {}; |
|
|
inMemCache = null; |
|
|
|
|
|
|
|
|
fs.unlink(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json', function(err) { |
|
|
fs.unlink(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json', function(err) { |
|
|
if (err) { |
|
|
if (err) { |
|
@ -183,6 +183,8 @@ cache.groomPost = function(req, res) { |
|
|
_payload = req.body.payload; |
|
|
_payload = req.body.payload; |
|
|
|
|
|
|
|
|
if (!cacheCallInProgress) { |
|
|
if (!cacheCallInProgress) { |
|
|
|
|
|
cacheCallInProgress = true; |
|
|
|
|
|
|
|
|
if (_filename) { |
|
|
if (_filename) { |
|
|
if (!_payload) { |
|
|
if (!_payload) { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
@ -192,11 +194,8 @@ cache.groomPost = function(req, res) { |
|
|
|
|
|
|
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} else { |
|
|
} else { |
|
|
if (inMemCache) { |
|
|
|
|
|
inMemCache = JSON.parse(_payload); |
|
|
inMemCache = JSON.parse(_payload); |
|
|
|
|
|
|
|
|
console.log('appending groom post to in mem cache'); |
|
|
console.log('appending groom post to in mem cache'); |
|
|
} else { |
|
|
|
|
|
console.log('appending groom post to on disk cache'); |
|
|
console.log('appending groom post to on disk cache'); |
|
|
|
|
|
|
|
|
fs.writeFile(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json', _payload, function (err) { |
|
|
fs.writeFile(cache.iguanaDir + '/shepherd/cache-' + _filename + '.json', _payload, function (err) { |
|
@ -206,6 +205,7 @@ cache.groomPost = function(req, res) { |
|
|
'result': err |
|
|
'result': err |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
cacheCallInProgress = false; |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
res.end(JSON.stringify(errorObj)); |
|
|
} else { |
|
|
} else { |
|
|
const successObj = { |
|
|
const successObj = { |
|
@ -213,11 +213,11 @@ cache.groomPost = function(req, res) { |
|
|
'result': 'done' |
|
|
'result': 'done' |
|
|
}; |
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
cacheCallInProgress = false; |
|
|
res.end(JSON.stringify(successObj)); |
|
|
res.end(JSON.stringify(successObj)); |
|
|
} |
|
|
} |
|
|
}); |
|
|
}); |
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
} else { |
|
|
} else { |
|
|
const errorObj = { |
|
|
const errorObj = { |
|
|
'msg': 'error', |
|
|
'msg': 'error', |
|
@ -289,15 +289,14 @@ cache.one = function(req, res, next) { |
|
|
|
|
|
|
|
|
if (!cacheCallInProgress) { |
|
|
if (!cacheCallInProgress) { |
|
|
cache.dumpCacheBeforeExit(); |
|
|
cache.dumpCacheBeforeExit(); |
|
|
fs.readFile(cache.iguanaDir + '/shepherd/cache-' + req.query.pubkey + '.json', 'utf8', function (err, data) { |
|
|
|
|
|
if (data) { |
|
|
let _data = fs.readFileSync(cache.iguanaDir + '/shepherd/cache-' + req.query.pubkey + '.json', 'utf8'); |
|
|
inMemCache = JSON.parse(data); |
|
|
if (_data) { |
|
|
data = data.replace('waiting', 'failed'); |
|
|
inMemCache = JSON.parse(_data); |
|
|
/*fs.writeFile(cache.iguanaDir + '/shepherd/cache-' + req.query.pubkey + '.json', data, function(err) { |
|
|
_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; |
|
|
|
|
|
|
|
@ -322,16 +321,6 @@ cache.one = function(req, res, next) { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
inMemCache = outObj; |
|
|
inMemCache = outObj; |
|
|
/*fs.writeFile(cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json', JSON.stringify(outObj), function(err) { |
|
|
|
|
|
if (err) { |
|
|
|
|
|
return console.log(err); |
|
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
console.log('file ' + cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json is updated'); |
|
|
|
|
|
if (timeStamp) { |
|
|
|
|
|
console.log('file ' + cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json is timestamped'); |
|
|
|
|
|
} |
|
|
|
|
|
});*/ |
|
|
|
|
|
}, |
|
|
}, |
|
|
checkTimestamp = function(dateToCheck) { |
|
|
checkTimestamp = function(dateToCheck) { |
|
|
var currentEpochTime = new Date(Date.now()) / 1000, |
|
|
var currentEpochTime = new Date(Date.now()) / 1000, |
|
@ -394,9 +383,11 @@ 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'); |
|
|
outObj = inMemCache; |
|
|
outObj = inMemCache; |
|
|
} else { |
|
|
} else { |
|
|
var _file = fs.readFileSync(cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json', 'utf8'); |
|
|
var _file = fs.readFileSync(cache.iguanaDir + '/shepherd/cache-' + pubkey + '.json', 'utf8'); |
|
|
|
|
|
console.log('cache one from disk'); |
|
|
//outObj = _file ? JSON.parse(_file) : {};
|
|
|
//outObj = _file ? JSON.parse(_file) : {};
|
|
|
outObj = fixJSON(_file); |
|
|
outObj = fixJSON(_file); |
|
|
} |
|
|
} |
|
|