Net::RDAP - an interface to the Registration Data Access Protocol (RDAP).
use Net::RDAP;
my $rdap = Net::RDAP->new;
#
# traditional lookup:
#
# get domain info:
$object = $rdap->domain('example.com');
# get info about IP addresses/ranges:
$object = $rdap->ip('192.168.0.1');
$object = $rdap->ip('2001:DB8::/32');
# get info about AS numbers:
$object = $rdap->autnum(65536);
#
# search functions:
#
my $server = Net::RDAP::Service->new("https://www.example.com/rdap");
# search for domains by name:
my $result = $server->domains('name' => 'ex*mple.com');
# search for entities by name:
my $result = $server->entities('fn' => 'J*n Doe');
# search for nameservers by IP address:
my $result = $server->nameservers('ip' => '192.168.56.101');
Net::RDAP provides an interface to the Registration Data Access Protocol (RDAP).
RDAP is replacing Whois as the preferred way of obtainining information about Internet resources (IP addresses, autonymous system numbers, and domain names). As of writing, RDAP is fully supported by Regional Internet Registries (who are responsible for the allocation of IP addresses and AS numbers) and generic TLD operators (e.g. .com, .org, .xyz) but is still being rolled out among country-code registries.
Net::RDAP does all the hard work of determining the correct server to query (Net::RDAP::Registry is an interface to the IANA registry of RDAP services), querying the server (Net::RDAP::UA is an RDAP HTTP user agent), and parsing the response (Net::RDAP::Object and its submodules provide access to the data returned by the server). As such, it provides a single unified interface to information about all unique Internet identifiers.
$rdap = Net::RDAP->new(%OPTIONS);
Constructor method, returns a new object. %OPTIONS is optional, but may contain any of the following options:
use_cache
- if true, copies of RDAP responses are stored on disk, and are updated if the copy on the server is more up-to-date. This behaviour is disabled by default and must be explicitly enabled. Note: this setting controls whether Net::RDAP caches RDAP records; it doesn't control caching of IANA registries by Net::RDAP::Registry and Net::RDAP::Values.cache_ttl
- if set, specifies how long after a record has been cached before Net::RDAP asks the server for any update. By default this is one hour (3600 seconds).
$object = $rdap->domain($domain);
This method returns a Net::RDAP::Object::Domain object containing
information about the domain name referenced by $domain
.
$domain
must be either a string or a Net::DNS::Domain object containing a
fully-qualified domain name. The domain may be either a "forward" domain
(such as example.com
) or a "reverse" domain (such as 168.192.in-addr.arpa
).
If there was an error, this method will return a Net::RDAP::Error.
Domain names which contain characters other than those from the ASCII-compatible range must be encoded into "A-label" (or "Punycode") format before being passed to Net::DNS::Domain. You can use Net::LibIDN or Net::LibIDN2 to perform this encoding:
use Net::LibIDN;
my $name = "espécime.com";
my $domain = $rdap->domain->(idn_to_ascii($name, 'UTF-8'));
$object = $rdap->ip($ip);
This method returns a Net::RDAP::Object::IPNetwork object containing
information about the resource referenced by $ip
.
$ip
must be either a string or a Net::IP object, and can represent any
of the following:
- An IPv4 address (e.g.
192.168.0.1
); - An IPv4 CIDR range (e.g.
192.168.0.1/16
); - An IPv6 address (e.g.
2001:DB8::42:1
); - An IPv6 CIDR range (e.g.
2001:DB8::/32
).
If there was an error, this method will return a Net::RDAP::Error.
$object = $rdap->autnum($autnum);
This method returns a Net::RDAP::Object::Autnum object containing
information about the autonymous system referenced by $autnum
.
$autnum
must be a a literal integer AS number or a Net::ASN object.
If there was an error, this method will return a Net::RDAP::Error.
$entity = $rdap->entity($handle);
This method returns a Net::RDAP::Object::Entity object containing
information about the entity referenced by $handle
, which must be
a string containing a "tagged" handle, such as ABC123-EXAMPLE
, as
per RFC 8521.
$exists = $rdap->exists($object);
This method returns a boolean indicating whether $object
(which
must be a Net::DNS::Domain, Net::IP or Net::ASN) exists. This
is determined by performing an HTTP HEAD
request and inspecting the
resulting HTTP status code.
Note: the non-existence of an object does not indicate whether that object is available for registration.
If there was an error, or no RDAP server is available for the specified object, this method will return a Net::RDAP::Error.
$object = $rdap->fetch($thing, %OPTIONS);
This method retrieves the resource identified by $thing
, which must
be either a URI or Net::RDAP::Link object, and returns a
Net::RDAP::Object object (assuming that the server returns a valid
RDAP response). This method is used internally by Net::RDAP but is
also available for when you want to directly fetch a resource without
using the IANA registry.
%OPTIONS
is an optional hash containing additional options for
the query. The following options are supported:
user
andpass
: if provided, they will be sent to the server in an HTTP Basic Authorization header field.class_override
: allows you to set or override theobjectClassName
property in RDAP responses.
my $svc = Net::RDAP::Service->new('https://www.example.com/rdap');
# $result is a Net::RDAP::SearchResult
my $result = $svc->domains('name' => 'ex*mple.com');
RDAP supports a limited search capability, but you need to know in advance which RDAP server you want to send the search query to.
The Net::RDAP::Service class allows you to prepare and submit search queries to specific RDAP servers. For more information, please see the documentation for that module.
# access the user agent
$ua = $rdap->ua;
# specify a cookie jar
$rdap->ua->cookie_jar('/tmp/cookies.txt');
# specify a proxy
$rdap->ua->proxy([qw(http https)], 'https://proxy.example.com');
You can access the Net::RDAP::UA object used to communicate with RDAP
servers using the ua()
method. This allows you to configure additional
HTTP features such as a file to store cookies, proxies, custom user-agent
strings, etc.
Net::RDAP is a work-in-progress; if you would like to help, the project is hosted here:
The Net::RDAP CPAN distribution contains a large number of RDAP-related modules that all work together. They are:
- Net::RDAP::Base
- Net::RDAP::EPPStatusMap
- Net::RDAP::JCard
- Net::RDAP::Registry
- Net::RDAP::Registry::IANARegistry
- Net::RDAP::Registry::IANARegistry::Service
- Net::RDAP::Service
- Net::RDAP::Link
- Net::RDAP::UA
- Net::RDAP::Values
- Net::RDAP::Variant
- Net::RDAP::VariantName
- https://tools.ietf.org/html/rfc7480 - HTTP Usage in the Registration Data Access Protocol (RDAP)
- https://tools.ietf.org/html/rfc7481 - Security Services for the Registration Data Access Protocol (RDAP)
- https://tools.ietf.org/html/rfc9082 - Registration Data Access Protocol (RDAP) Query Format
- https://tools.ietf.org/html/rfc9083 - JSON Responses for the Registration Data Access Protocol (RDAP)
- https://tools.ietf.org/html/rfc9224 - Finding the Authoritative Registration Data (RDAP) Service
- https://tools.ietf.org/html/rfc8056 - Extensible Provisioning Protocol (EPP) and Registration Data Access Protocol (RDAP) Status Mapping
- https://tools.ietf.org/html/rfc8288 - Web Linking
- https://tools.ietf.org/html/rfc8521 - Registration Data Access Protocol (RDAP) Object Tagging
- https://tools.ietf.org/html/rfc9536 - Registration Data Access Protocol (RDAP) Reverse Search
- https://tools.ietf.org/html/rfc9537 - Redacted Fields in the Registration Data Access Protocol (RDAP) Response
Copyright 2018-2023 CentralNic Ltd, 2024 Gavin Brown. All rights reserved.
Permission to use, copy, modify, and distribute this software and its documentation for any purpose and without fee is hereby granted, provided that the above copyright notice appear in all copies and that both that copyright notice and this permission notice appear in supporting documentation, and that the name of the author not be used in advertising or publicity pertaining to distribution of the software without specific prior written permission.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.