bitcore-wallet-service/lib/blockchainexplorers/request-list.js

62 lines
1.5 KiB
JavaScript
Raw Normal View History

2016-02-16 12:09:53 -08:00
var _ = require('lodash');
var async = require('async');
var $ = require('preconditions').singleton();
var log = require('npmlog');
log.debug = log.verbose;
2016-07-21 11:41:29 -07:00
2016-07-21 12:21:36 -07:00
var DEFAULT_TIMEOUT= 60000; // 60 s
2016-02-16 12:09:53 -08:00
/**
* Query a server, using one of the given options
*
* @param {Object} opts
* @param {Array} opts.hosts Array of hosts to query. Until the first success one.
* @param {Array} opts.path Path to request in each server
*/
2016-02-16 19:15:43 -08:00
var requestList = function(args, cb) {
2016-02-16 12:09:53 -08:00
$.checkArgument(args.hosts);
request = args.request || require('request');
if (!_.isArray(args.hosts))
args.hosts = [args.hosts];
2016-07-21 11:41:29 -07:00
args.timeout = args.timeout || DEFAULT_TIMEOUT;
2016-02-16 12:09:53 -08:00
var urls = _.map(args.hosts, function(x) {
return (x + args.path);
});
var nextUrl, result, success;
async.whilst(
function() {
nextUrl = urls.shift();
return nextUrl && !success;
},
function(a_cb) {
args.uri = nextUrl;
request(args, function(err, res, body) {
if (err) {
log.warn('REQUEST FAIL: ' + nextUrl + ' ERROR: ' + err);
}
if (res) {
success = !!res.statusCode.toString().match(/^[1234]../);
if (!success) {
log.warn('REQUEST FAIL: ' + nextUrl + ' STATUS CODE: ' + res.statusCode);
}
}
result = [err, res, body];
return a_cb();
});
},
function(err) {
if (err) return cb(err);
return cb(result[0], result[1], result[2]);
}
);
};
2016-02-16 19:15:43 -08:00
module.exports = requestList;