Expand description
§IPTable
This crate contains an efficient data structure for storing and querying values by CIDR.
§Examples
use iptable::Ipv4Table;
use ipnetwork::Ipv4Network;
let mut table = Ipv4Table::new();
table.insert("192.168.2.0/24".parse::<Ipv4Network>().unwrap(), 42);
table.insert("192.168.1.0/24".parse::<Ipv4Network>().unwrap(), 43);
assert_eq!(table.get("192.168.2.0/24".parse::<Ipv4Network>().unwrap()), Some(&42));
// Iterate over the prefixes under a given prefix
let ipnet: Ipv4Network = "192.168.0.0/16".parse().unwrap();
let relevant = table.iter_prefix(ipnet).collect::<Vec<_>>();
assert_eq!(2, relevant.len());
// Find unassigned /20s in the table
let unassigned = table.gaps(
"192.168.0.0/18".parse::<Ipv4Network>().unwrap(), Some(20))
.collect::<Vec<_>>();
assert_eq!(
unassigned, vec![
"192.168.16.0/20".parse().unwrap(),
"192.168.32.0/19".parse().unwrap()]);
// Merge entries with longer prefixes
let merged_table = table.merge_longer_prefixes(16, |a, b| a + b);
assert_eq!(
merged_table.iter().collect::<Vec<_>>(),
vec![(&"192.168.0.0/16".parse().unwrap(), &85)]
);
Structs§
- Generic
IpTable - Base structure for storing values by CIDR.
Traits§
- Subnet
- A trait for types that can be used as subnets.
Functions§
- exact_
prefixes - Iterate over all prefixes with the given prefix length.
- surrounding_
gaps - Find all gaps in prefix before the given child prefix.
Type Aliases§
- IpTable
- A table for storing values by IPv4 or IPv6 CIDR.
- Ipv4
Table - A table for storing values by IPv4 CIDR.
- Ipv6
Table - A table for storing values by IPv6 CIDR.
- Universal
IpTable - Alias for IpTable