Documentation ¶
Overview ¶
Package cidranger provides utility to store CIDR blocks and perform ip inclusion tests against it.
To create a new instance of the path-compressed trie:
ranger := NewPCTrieRanger()
To insert or remove an entry (any object that satisfies the RangerEntry interface):
_, network, _ := net.ParseCIDR("192.168.0.0/24") ranger.Insert(NewBasicRangerEntry(*network)) ranger.Remove(network)
If you desire for any value to be attached to the entry, simply create custom struct that satisfies the RangerEntry interface:
type RangerEntry interface { Network() net.IPNet }
To test whether an IP is contained in the constructed networks ranger:
// returns bool, error containsBool, err := ranger.Contains(net.ParseIP("192.168.0.1"))
To get a list of CIDR blocks in constructed ranger that contains IP:
// returns []RangerEntry, error entries, err := ranger.ContainingNetworks(net.ParseIP("192.168.0.1"))
To get a list of all IPv4/IPv6 rangers respectively:
// returns []RangerEntry, error entries, err := ranger.CoveredNetworks(*AllIPv4) entries, err := ranger.CoveredNetworks(*AllIPv6)
Index ¶
Constants ¶
This section is empty.
Variables ¶
var AllIPv4 = parseCIDRUnsafe("0.0.0.0/0")
AllIPv4 is a IPv4 CIDR that contains all networks
var AllIPv6 = parseCIDRUnsafe("0::0/0")
AllIPv6 is a IPv6 CIDR that contains all networks
var ErrInvalidNetworkInput = fmt.Errorf("invalid network input")
ErrInvalidNetworkInput is returned upon invalid network input.
var ErrInvalidNetworkNumberInput = fmt.Errorf("invalid network number input")
ErrInvalidNetworkNumberInput is returned upon invalid network input.
Functions ¶
This section is empty.
Types ¶
type Ranger ¶
type Ranger interface { Insert(entry RangerEntry) error Remove(network netip.Prefix) (RangerEntry, error) Contains(ip netip.Addr) (bool, error) ContainingNetworks(ip netip.Addr) ([]RangerEntry, error) CoveredNetworks(network netip.Prefix) ([]RangerEntry, error) CoveringNetworks(network netip.Prefix) ([]RangerEntry, error) Adjacent(network netip.Prefix) (RangerEntry, error) Len() int }
Ranger is an interface for cidr block containment lookups.
func NewPCTrieRanger ¶
func NewPCTrieRanger() Ranger
NewPCTrieRanger returns a versionedRanger that supports both IPv4 and IPv6 using the path compressed trie implemention.
type RangerEntry ¶
RangerEntry is an interface for insertable entry into a Ranger.
func NewBasicRangerEntry ¶
func NewBasicRangerEntry(ipNet netip.Prefix) RangerEntry
NewBasicRangerEntry returns a basic RangerEntry that only stores the network itself.