/** * Module dependencies. */ var dns = require('dns'); var Netmask = require('netmask').Netmask; /** * Module exports. */ module.exports = isInNet; isInNet.async = true; /** * True iff the IP address of the host matches the specified IP address pattern. * * Pattern and mask specification is done the same way as for SOCKS configuration. * * Examples: * * ``` js * isInNet(host, "198.95.249.79", "255.255.255.255") * // is true iff the IP address of host matches exactly 198.95.249.79. * * isInNet(host, "198.95.0.0", "255.255.0.0") * // is true iff the IP address of the host matches 198.95.*.*. * ``` * * @param {String} host a DNS hostname, or IP address. If a hostname is passed, * it will be resoved into an IP address by this function. * @param {String} pattern an IP address pattern in the dot-separated format mask. * @param {String} mask for the IP address pattern informing which parts of the * IP address should be matched against. 0 means ignore, 255 means match. * @return {Boolean} */ function isInNet (host, pattern, mask, fn) { var family = 4; dns.lookup(host, family, function (err, ip) { if (err) return fn(err); if (!ip) ip = '127.0.0.1'; var netmask = new Netmask(pattern, mask); fn(null, netmask.contains(ip)); }); }