Skip to content

Commit

Permalink
Squased commits, made changes to isIpRange to avoid array destructuring.
Browse files Browse the repository at this point in the history
  • Loading branch information
Daniel Guimaraes committed Jun 12, 2018
1 parent 2e6cc37 commit 1cb0900
Show file tree
Hide file tree
Showing 4 changed files with 19 additions and 107 deletions.
19 changes: 6 additions & 13 deletions lib/isIPRange.js
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,6 @@
Object.defineProperty(exports, "__esModule", {
value: true
});

var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }();

exports.default = isIPRange;

var _assertString = require('./util/assertString');
Expand All @@ -22,26 +19,22 @@ var subnetMaybe = /^\d{1,2}$/;

function isIPRange(str) {
(0, _assertString2.default)(str);
var parts = str.split('/');

var _str$split = str.split('/'),
_str$split2 = _slicedToArray(_str$split, 3),
ip = _str$split2[0],
subnet = _str$split2[1],
err = _str$split2[2];

if (typeof err !== 'undefined') {
// parts[0] -> ip, parts[1] -> subnet
if (parts.length !== 2) {
return false;
}

if (!subnetMaybe.test(subnet)) {
if (!subnetMaybe.test(parts[1])) {
return false;
}

// Disallow preceding 0 i.e. 01, 02, ...
if (subnet.length > 1 && subnet.startsWith('0')) {
if (parts[1].length > 1 && parts[1].startsWith('0')) {
return false;
}

return (0, _isIP2.default)(ip) && subnet <= 32 && subnet >= 0;
return (0, _isIP2.default)(parts[0], 4) && parts[1] <= 32 && parts[1] >= 0;
}
module.exports = exports['default'];
11 changes: 6 additions & 5 deletions src/lib/isIPRange.js
Original file line number Diff line number Diff line change
Expand Up @@ -5,20 +5,21 @@ const subnetMaybe = /^\d{1,2}$/;

export default function isIPRange(str) {
assertString(str);
const [ip, subnet, err] = str.split('/');
const parts = str.split('/');

if (typeof err !== 'undefined') {
// parts[0] -> ip, parts[1] -> subnet
if (parts.length !== 2) {
return false;
}

if (!subnetMaybe.test(subnet)) {
if (!subnetMaybe.test(parts[1])) {
return false;
}

// Disallow preceding 0 i.e. 01, 02, ...
if (subnet.length > 1 && subnet.startsWith('0')) {
if (parts[1].length > 1 && parts[1].startsWith('0')) {
return false;
}

return isIP(ip, 4) && subnet <= 32 && subnet >= 0;
return isIP(parts[0], 4) && parts[1] <= 32 && parts[1] >= 0;
}
94 changes: 6 additions & 88 deletions validator.js
Original file line number Diff line number Diff line change
Expand Up @@ -69,84 +69,6 @@ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol
return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
};









































var slicedToArray = function () {
function sliceIterator(arr, i) {
var _arr = [];
var _n = true;
var _d = false;
var _e = undefined;

try {
for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {
_arr.push(_s.value);

if (i && _arr.length === i) break;
}
} catch (err) {
_d = true;
_e = err;
} finally {
try {
if (!_n && _i["return"]) _i["return"]();
} finally {
if (_d) throw _e;
}
}

return _arr;
}

return function (arr, i) {
if (Array.isArray(arr)) {
return arr;
} else if (Symbol.iterator in Object(arr)) {
return sliceIterator(arr, i);
} else {
throw new TypeError("Invalid attempt to destructure non-iterable instance");
}
};
}();

function toString(input) {
if ((typeof input === 'undefined' ? 'undefined' : _typeof(input)) === 'object' && input !== null) {
if (typeof input.toString === 'function') {
Expand Down Expand Up @@ -540,27 +462,23 @@ var subnetMaybe = /^\d{1,2}$/;

function isIPRange(str) {
assertString(str);
var parts = str.split('/');

var _str$split = str.split('/'),
_str$split2 = slicedToArray(_str$split, 3),
ip = _str$split2[0],
subnet = _str$split2[1],
err = _str$split2[2];

if (typeof err !== 'undefined') {
// parts[0] -> ip, parts[1] -> subnet
if (parts.length !== 2) {
return false;
}

if (!subnetMaybe.test(subnet)) {
if (!subnetMaybe.test(parts[1])) {
return false;
}

// Disallow preceding 0 i.e. 01, 02, ...
if (subnet.length > 1 && subnet.startsWith('0')) {
if (parts[1].length > 1 && parts[1].startsWith('0')) {
return false;
}

return isIP(ip) && subnet <= 32 && subnet >= 0;
return isIP(parts[0], 4) && parts[1] <= 32 && parts[1] >= 0;
}

function isBoolean(str) {
Expand Down
Loading

0 comments on commit 1cb0900

Please sign in to comment.