REV
REV
returns the reverse lookup domain for an IP network. For example REV("1.2.3.0/24")
returns 3.2.1.in-addr.arpa.
and REV("2001:db8:302::/48")
returns 2.0.3.0.8.b.d.0.1.0.0.2.ip6.arpa.
.
REV()
is commonly used with the D()
functions to create reverse DNS lookup zones.
These two are equivalent:
The latter is easier to type and less error-prone.
If the address does not include a "/" then REV()
assumes /32 for IPv4 addresses and /128 for IPv6 addresses.
RFC compliance
REV()
implements both RFC 2317 and the newer RFC 4183. The REVCOMPAT()
function selects which mode is used. If REVCOMPAT()
is not called, a default is selected for you. The default will change to RFC 4183 in DNSControl v5.0.
See REVCOMPAT()
for details.
Host bits
v4.x: The host bits (the ones outside the netmask) must be zeros. They are not zeroed out automatically. Thus, REV("1.2.3.4/24")
is an error.
v5.0 and later: The host bits (the ones outside the netmask) are ignored. Thus REV("1.2.3.4/24")
and REV("1.2.3.0/24")
are equivalent.
Examples
Here's an example reverse lookup domain:
Automatic forward and reverse record generation
DNSControl does not automatically generate forward and reverse lookups. However it is possible to write a macro that does this. See PTR()
for an example.
Last updated