cidr-tools 10.1.1 → 11.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +32 -8
- package/dist/index.d.ts +2 -3
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -4
- package/package.json +7 -7
package/README.md
CHANGED
|
@@ -7,13 +7,26 @@
|
|
|
7
7
|
```js
|
|
8
8
|
import {mergeCidr, excludeCidr, expandCidr, overlapCidr, containsCidr, normalizeCidr, parseCidr} from "cidr-tools";
|
|
9
9
|
|
|
10
|
-
mergeCidr(["1.0.0.0/24", "1.0.1.0/24"]);
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
10
|
+
mergeCidr(["1.0.0.0/24", "1.0.1.0/24"]);
|
|
11
|
+
//=> ["1.0.0.0/23"]
|
|
12
|
+
|
|
13
|
+
excludeCidr(["::1/127"], "::1/128");
|
|
14
|
+
//=> ["::/128"]
|
|
15
|
+
|
|
16
|
+
Array.from(expandCidr(["2001:db8::/126"]));
|
|
17
|
+
//=> ["2001:db8::", "2001:db8::1", "2001:db8::2", "2001:db8::3"]
|
|
18
|
+
|
|
19
|
+
overlapCidr("1.0.0.0/24", "1.0.0.128/25");
|
|
20
|
+
//=> true
|
|
21
|
+
|
|
22
|
+
containsCidr(["1.0.0.0/24", "2.0.0.0/24"], "1.0.0.1");
|
|
23
|
+
//=> true
|
|
24
|
+
|
|
25
|
+
normalizeCidr("::ffff/64");
|
|
26
|
+
//=> "::/64"
|
|
27
|
+
|
|
28
|
+
parseCidr("::/64");
|
|
29
|
+
// => {cidr: "::/64", version: 6, prefix: "64", start: 0n, end: 18446744073709551615n}
|
|
17
30
|
```
|
|
18
31
|
|
|
19
32
|
## API
|
|
@@ -41,7 +54,18 @@ Returns an array of merged remaining networks.
|
|
|
41
54
|
|
|
42
55
|
- `networks` *String* or *Array*: One or more CIDR or IP addresses.
|
|
43
56
|
|
|
44
|
-
Returns
|
|
57
|
+
Returns a generator for individual IPs contained in the networks.
|
|
58
|
+
|
|
59
|
+
Be aware that passing large networks that contain millions of IPs can result in memory exhaustion and slow execution time. It's recommended to validate the amount of IPs first, for example, like this:
|
|
60
|
+
|
|
61
|
+
```js
|
|
62
|
+
import {parseCidr} from "cidr-tools";
|
|
63
|
+
|
|
64
|
+
const {start, end} = parseCidr("1.2.3.4/2");
|
|
65
|
+
if (end - start >= 1000000n) {
|
|
66
|
+
throw new Error("Too many IPs");
|
|
67
|
+
}
|
|
68
|
+
```
|
|
45
69
|
|
|
46
70
|
### overlapCidr(networksA, networksB)
|
|
47
71
|
|
package/dist/index.d.ts
CHANGED
|
@@ -18,12 +18,11 @@ type NormalizeOpts = {
|
|
|
18
18
|
compress?: boolean;
|
|
19
19
|
hexify?: boolean;
|
|
20
20
|
};
|
|
21
|
-
export declare function normalizeCidr(cidr:
|
|
22
|
-
export declare function normalizeCidr(cidr: Network[], opts?: NormalizeOpts): Network[];
|
|
21
|
+
export declare function normalizeCidr<T extends Network | Network[]>(cidr: T, opts?: NormalizeOpts): T;
|
|
23
22
|
export declare function parseCidr(str: Network): ParsedCidr;
|
|
24
23
|
export declare function mergeCidr(nets: Networks): Network[];
|
|
25
24
|
export declare function excludeCidr(base: Networks, excl: Networks): Network[];
|
|
26
|
-
export declare function expandCidr(nets: Networks): Network
|
|
25
|
+
export declare function expandCidr(nets: Networks): Generator<Network>;
|
|
27
26
|
export declare function overlapCidr(a: Networks, b: Networks): boolean;
|
|
28
27
|
export declare function containsCidr(a: Networks, b: Networks): boolean;
|
|
29
28
|
declare const _default: {
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAIA,KAAK,WAAW,GAAG,MAAM,CAAC;AAC1B,KAAK,WAAW,GAAG,MAAM,CAAC;AAC1B,KAAK,QAAQ,GAAG,MAAM,CAAC;AACvB,KAAK,QAAQ,GAAG,MAAM,CAAC;AAEvB,KAAK,OAAO,GAAG,WAAW,GAAG,QAAQ,GAAG,WAAW,GAAG,QAAQ,CAAC;AAC/D,KAAK,QAAQ,GAAG,OAAO,GAAG,OAAO,EAAE,CAAC;AAEpC,KAAK,cAAc,GAAG,CAAC,GAAG,CAAC,CAAC;AAE5B,KAAK,UAAU,GAAG;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,cAAc,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,aAAa,EAAE,OAAO,CAAC;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,KAAK,aAAa,GAAG;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAqCF,wBAAgB,aAAa,CAAC,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../index.ts"],"names":[],"mappings":"AAIA,KAAK,WAAW,GAAG,MAAM,CAAC;AAC1B,KAAK,WAAW,GAAG,MAAM,CAAC;AAC1B,KAAK,QAAQ,GAAG,MAAM,CAAC;AACvB,KAAK,QAAQ,GAAG,MAAM,CAAC;AAEvB,KAAK,OAAO,GAAG,WAAW,GAAG,QAAQ,GAAG,WAAW,GAAG,QAAQ,CAAC;AAC/D,KAAK,QAAQ,GAAG,OAAO,GAAG,OAAO,EAAE,CAAC;AAEpC,KAAK,cAAc,GAAG,CAAC,GAAG,CAAC,CAAC;AAE5B,KAAK,UAAU,GAAG;IAChB,IAAI,EAAE,MAAM,CAAC;IACb,EAAE,EAAE,MAAM,CAAC;IACX,OAAO,EAAE,cAAc,CAAC;IACxB,MAAM,EAAE,MAAM,CAAC;IACf,aAAa,EAAE,OAAO,CAAC;IACvB,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,EAAE,MAAM,CAAC;CACb,CAAC;AAEF,KAAK,aAAa,GAAG;IACnB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAqCF,wBAAgB,aAAa,CAAC,CAAC,SAAS,OAAO,GAAG,OAAO,EAAE,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,aAAa,GAAG,CAAC,CAQ7F;AAED,wBAAgB,SAAS,CAAC,GAAG,EAAE,OAAO,GAAG,UAAU,CAqClD;AAkOD,wBAAgB,SAAS,CAAC,IAAI,EAAE,QAAQ,GAAG,OAAO,EAAE,CAWnD;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,QAAQ,GAAG,OAAO,EAAE,CAgCrE;AAED,wBAAiB,UAAU,CAAC,IAAI,EAAE,QAAQ,GAAG,SAAS,CAAC,OAAO,CAAC,CAS9D;AAED,wBAAgB,WAAW,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,GAAG,OAAO,CAqB7D;AAED,wBAAgB,YAAY,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,EAAE,QAAQ,GAAG,OAAO,CAwB9D;;;;;;;;;;AAED,wBAQE"}
|
package/dist/index.js
CHANGED
|
@@ -234,16 +234,14 @@ function excludeCidr(base, excl) {
|
|
|
234
234
|
}
|
|
235
235
|
return bases[4].concat(bases[6]).sort(compare);
|
|
236
236
|
}
|
|
237
|
-
function expandCidr(nets) {
|
|
237
|
+
function* expandCidr(nets) {
|
|
238
238
|
const arr = uniq(Array.isArray(nets) ? nets : [nets]);
|
|
239
|
-
const ips = [];
|
|
240
239
|
for (const net of mergeCidr(arr)) {
|
|
241
240
|
const { start, end, version } = parseCidr(net);
|
|
242
241
|
for (let number = start; number <= end; number++) {
|
|
243
|
-
|
|
242
|
+
yield normalizeCidr(stringifyIp({ number, version }));
|
|
244
243
|
}
|
|
245
244
|
}
|
|
246
|
-
return ips.map((ip) => normalizeCidr(ip));
|
|
247
245
|
}
|
|
248
246
|
function overlapCidr(a, b) {
|
|
249
247
|
const aNets = uniq(Array.isArray(a) ? a : [a]);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "cidr-tools",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "11.0.1",
|
|
4
4
|
"author": "silverwind <me@silverwind.io>",
|
|
5
5
|
"description": "Tools to work with IPv4 and IPv6 CIDR",
|
|
6
6
|
"repository": "silverwind/cidr-tools",
|
|
@@ -21,14 +21,14 @@
|
|
|
21
21
|
},
|
|
22
22
|
"devDependencies": {
|
|
23
23
|
"eslint": "8.57.0",
|
|
24
|
-
"eslint-config-silverwind": "
|
|
25
|
-
"eslint-config-silverwind-typescript": "
|
|
26
|
-
"typescript-config-silverwind": "
|
|
27
|
-
"updates": "16.
|
|
24
|
+
"eslint-config-silverwind": "91.0.2",
|
|
25
|
+
"eslint-config-silverwind-typescript": "8.0.4",
|
|
26
|
+
"typescript-config-silverwind": "6.0.0",
|
|
27
|
+
"updates": "16.4.0",
|
|
28
28
|
"versions": "12.1.2",
|
|
29
|
-
"vite": "5.
|
|
29
|
+
"vite": "5.4.2",
|
|
30
30
|
"vite-config-silverwind": "3.0.0",
|
|
31
|
-
"vitest": "2.0.
|
|
31
|
+
"vitest": "2.0.5",
|
|
32
32
|
"vitest-config-silverwind": "9.1.0"
|
|
33
33
|
}
|
|
34
34
|
}
|