Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

@chainsafe/is-ip

ChainSafe297.2kMIT2.0.2TypeScript support: included

Check if a string is an IP address

ip, ipv6, ipv4, regex, regexp, match, test, find, text, pattern, internet, protocol, address, validate, detect, check, is, string

readme

@chainsafe/is-ip

Check if a string is an IP address

Install

npm install @chainsafe/is-ip

Example

Check if a string is an IP address

import { expect } from "chai";
import {
    isIPv4,
    isIPv6,
    isIP,
    ipVersion,
} from "@chainsafe/is-ip";

// check if a string is a valid IPv4
expect(isIPv4("127.0.0.1")).to.equal(true);

// check if a string is a valid IPv6
expect(isIPv6("127.0.0.1")).to.equal(false);

// check if a string is a valid IPv4 or IPv6
expect(isIP("127.0.0.1")).to.equal(true);

// return 4, 6, or undefined
expect(ipVersion("127.0.0.1")).to.equal(4);
expect(ipVersion("1:2:3:4:5:6:7:8")).to.equal(6);
expect(ipVersion("invalid ip")).to.equal(undefined);

Parse a string into IP address bytes

import { expect } from "chai";
import {
    parseIPv4,
    parseIPv6,
    parseIP,
} from "@chainsafe/is-ip/parse";

// parse a string into IPv4 bytes
const b1 = parseIPv4("127.0.0.1");
expect(b1).to.deep.equal(Uint8Array.from([127, 0, 0, 1]));

// parse a string into IPv6 bytes
const b2 = parseIPv6("::1");
expect(b2).to.deep.equal(Uint8Array.from([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]));

// parse a string into either IPv4 or IPv6 bytes
const b3 = parseIP("127.0.0.1");
expect(b3).to.deep.equal(Uint8Array.from([127, 0, 0, 1]));

const b4 = parseIP("::1");
expect(b4).to.deep.equal(Uint8Array.from([0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1]));

// parseIP* functions return undefined on invalid input
expect(parseIP("not an IP")).to.equal(undefined);

License

MIT

changelog

Changelog

2.0.2 (2023-08-11)

Bug Fixes

  • support parsing IPv6 addresses with zone indexes in browsers (#10) (9454b59)

2.0.1 (2022-10-29)

Bug Fixes

2.0.0 (2022-10-29)

⚠ BREAKING CHANGES

  • faster impl and node impl (#3)

Features

Bug Fixes

Miscellaneous