cidr-tools 10.1.1 → 11.0.0

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 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"]); //=> ["1.0.0.0/23"]
11
- excludeCidr(["::1/127"], "::1/128") //=> ["::/128"]
12
- expandCidr(["2001:db8::/126"]) //=> ["2001:db8::", "2001:db8::1", "2001:db8::2", "2001:db8::3"]
13
- overlapCidr("1.0.0.0/24", "1.0.0.128/25") //=> true
14
- containsCidr(["1.0.0.0/24", "2.0.0.0/24"], "1.0.0.1") //=> true
15
- normalizeCidr("::ffff/64") //=> "::/64"
16
- parseCidr("::/64"); // => {cidr: "::/64", version: 6, prefix: "64", start: 0n, end: 18446744073709551615n}
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,7 @@ 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 an array of individual IPs contained in the networks.
57
+ Returns a generator for individual IPs contained in the networks. Be aware that asking for expansions of big networks can result in long runtimes and possibly high memory usage. One million IPs takes about 2 seconds on modern hardware.
45
58
 
46
59
  ### overlapCidr(networksA, networksB)
47
60
 
package/dist/index.d.ts CHANGED
@@ -23,7 +23,7 @@ export declare function normalizeCidr(cidr: Network[], opts?: NormalizeOpts): Ne
23
23
  export declare function parseCidr(str: Network): ParsedCidr;
24
24
  export declare function mergeCidr(nets: Networks): Network[];
25
25
  export declare function excludeCidr(base: Networks, excl: Networks): Network[];
26
- export declare function expandCidr(nets: Networks): Network[];
26
+ export declare function expandCidr(nets: Networks): Generator<Network>;
27
27
  export declare function overlapCidr(a: Networks, b: Networks): boolean;
28
28
  export declare function containsCidr(a: Networks, b: Networks): boolean;
29
29
  declare const _default: {
@@ -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,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,aAAa,GAAG,OAAO,CAAC;AAC5E,wBAAgB,aAAa,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,IAAI,CAAC,EAAE,aAAa,GAAG,OAAO,EAAE,CAAC;AAShF,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,wBAAgB,UAAU,CAAC,IAAI,EAAE,QAAQ,GAAG,OAAO,EAAE,CAWpD;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"}
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,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,aAAa,GAAG,OAAO,CAAC;AAC5E,wBAAgB,aAAa,CAAC,IAAI,EAAE,OAAO,EAAE,EAAE,IAAI,CAAC,EAAE,aAAa,GAAG,OAAO,EAAE,CAAC;AAShF,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
- ips.push(stringifyIp({ number, version }));
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": "10.1.1",
3
+ "version": "11.0.0",
4
4
  "author": "silverwind <me@silverwind.io>",
5
5
  "description": "Tools to work with IPv4 and IPv6 CIDR",
6
6
  "repository": "silverwind/cidr-tools",