cidr_match
Function
cidr_match — test if IP is in a network
Synopsis
cidr_match(network: net, val: any) -> bool
Description
The cidr_match function returns true if val contains an IP address that
falls within the network given by network. When val is a complex type, the
function traverses its nested structure to find any ip values.
If network is not type net, then an error is returned.
Examples
Test whether values are IP addresses in a network:
echo '10.1.2.129 11.1.2.129 10 "foo"' | zq -z 'yield cidr_match(10.0.0.0/8, this)' -
=>
true
false
false
false
It also works for IPs in complex values:
echo '[10.1.2.129,11.1.2.129] {a:10.0.0.1} {a:11.0.0.1}' | zq -z 'yield cidr_match(10.0.0.0/8, this)' -
=>
true
true
false
The first argument must be a network:
echo '10.0.0.1' | zq -z 'yield cidr_match([1,2,3], this)' -
=>
error({message:"cidr_match: not a net",on:[1,2,3]})