49 lines
1.3 KiB
JavaScript
49 lines
1.3 KiB
JavaScript
|
|
||
|
/**
|
||
|
* 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));
|
||
|
});
|
||
|
}
|