bogon

Crates.iobogon
lib.rsbogon
version0.2.1
sourcesrc
created_at2024-04-30 16:36:53.499348
updated_at2024-10-04 15:18:21.539141
descriptionA Rust library to check if an IP address is a bogon
homepage
repositoryhttps://github.com/Alextopher/bogon
max_upload_size
id1225231
size32,542
Christopher Mahoney (Alextopher)

documentation

README

Bogon

Rust Crates.io Docs.rs

Bogon is a Rust library for checking whether an IP address is considered "bogus" or "bogon", meaning it's not valid for use on the public internet. This includes private IP addresses, loopback addresses, and other reserved addresses.

Features

  • Supports both IPv4 and IPv6 addresses.
  • Includes methods for checking bogus IP addresses using extension traits.
  • Strives to be as fast as possible. The compiler generates SIMD instructions for both IPv4 and IPv6 address checks.
  • IPv6 ranges are generated at build time from the IANA reserved address registry.
  • The download feature can be enabled to download the latest reserved address ranges from the IANA registry at build time.
  • No dependencies, no_std compatible.

TODO

  • Updating address ranges at runtime.

MSRV

Rust 1.80 is the minimum supported rust version due to the use of to_bits(). It's unlikely that the MSRV will be increased in the future.

Examples

use core::net::{IpAddr, Ipv4Addr, Ipv6Addr};

assert_eq!(bogon::is_bogon_str("127.0.0.1"), Ok(true));
assert_eq!(bogon::is_bogon_str("8.8.8.8"), Ok(false));
assert_eq!(bogon::is_bogon_str("::1"), Ok(true));
assert!(bogon::is_bogon_str("foo").is_err());

assert_eq!(bogon::is_bogon_v4(Ipv4Addr::new(127, 0, 0, 1)), true);
assert_eq!(bogon::is_bogon_v4(Ipv4Addr::new(8, 8, 8, 8)), false);
assert_eq!(bogon::is_bogon_v6(Ipv6Addr::new(0, 0, 0, 0, 0, 0, 0, 1)), true);

assert_eq!(bogon::is_bogon(IpAddr::V4(Ipv4Addr::new(127, 0, 0, 1))), true);
assert_eq!(bogon::is_bogon(IpAddr::V4(Ipv4Addr::new(8, 8, 8, 8))), false);
assert_eq!(bogon::is_bogon(IpAddr::V6(Ipv6Addr::new(0, 0, 0, 0, 0, 0, 0, 1))), true);

use bogon::BogonExt;

assert_eq!(IpAddr::V4(Ipv4Addr::new(127, 0, 0, 1)).is_bogon(), true);
assert_eq!(IpAddr::V4(Ipv4Addr::new(8, 8, 8, 8)).is_bogon(), false);
assert_eq!(IpAddr::V6(Ipv6Addr::new(0, 0, 0, 0, 0, 0, 0, 1)).is_bogon(), true);
Commit count: 17

cargo fmt