This repository was archived by the owner on Nov 16, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathindex.js
111 lines (88 loc) · 2.02 KB
/
index.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
/**
* Module dependencies.
*/
var debug = require('debug')('nsq-lookup');
var request = require('superagent');
var Batch = require('batch');
/**
* Retry support.
*/
require('superagent-retry')(request);
/**
* Expose `lookup()`.
*/
exports = module.exports = lookup;
/**
* Lookup using nsqlookupd `addrs`.
*
* @param {Array} addrs
* @param {Function} fn
* @api public
*/
function lookup(addrs, opts, fn) {
var batch = new Batch;
batch.throws(false);
batch.concurrency(addrs.length);
if ('function' == typeof opts) {
fn = opts;
opts = {};
}
var timeout = opts.timeout || 20000;
var retries = opts.retries || 2;
if (!opts.topic) {
return fn(new Error('invalid or missing topic'), null);
}
addrs.forEach(function(addr){
debug('lookup %s for topic %s', addr, opts.topic);
batch.push(function(done){
request
.get(addr + '/lookup?topic=' + opts.topic)
.timeout(timeout)
.retry(retries)
.end(function(err, res){
if (err) return done(err);
if (res.error) return done(res.error);
var data = res.body && res.body.data || {};
var producers = data.producers || [];
done(null, producers);
})
});
});
batch.end(function(errors, results){
errors = filter(errors);
results = filter(results);
results = dedupe(results);
debug('errors=%j results=%j', errors, results);
fn(errors.length ? errors : null, results);
});
}
/**
* Drops null and uddefined.
*/
function filter(arr) {
arry = arr || [];
return arr.filter(function(v){
return v != null;
});
}
/**
* Dedupe `results`.
*
* @param {Array} results
* @return {Array}
* @api private
*/
function dedupe(results) {
results = results || [];
var ret = [];
var set = {};
results.forEach(function(nodes){
nodes.forEach(function(node){
var addr = node.broadcast_address + ':' + node.tcp_port;
if (set[addr]) return debug('already registered');
set[addr] = true;
ret.push(node);
});
});
return ret;
}