RDAP is a protocol to query domain registration data. It is seen as the successor to WHOIS. The main advantage of WHOIS is that the returned data is standardized and structured as JSON. A downside of RDAP is that, at the moment of writing, not all TLDs are supported.
This package contains a few classes to query basic data from RDAP. It also provides caching of the responses out of the box.
We invest a lot of resources into creating best in class open source packages. You can support us by buying one of our paid products.
We highly appreciate you sending us a postcard from your hometown, mentioning which of our package(s) you are using. You'll find our address on our contact page. We publish all received postcards on our virtual postcard wall.
You can install the package via composer:
composer require spatie/laravel-rdap
You can publish the config file with:
php artisan vendor:publish --tag="laravel-rdap-config"
This is the contents of the published config file:
return [
/*
* When making an RDAP query, we first have got to make a request to determine
* the server responsible for the tld of the query. Here you can specify
* how long we should cache the server URLs.
*/
'tld_servers_cache' => [
'store_name' => null,
'duration_in_seconds' => CarbonInterval::week()->totalSeconds,
],
];
You can get resolve a configured Rdap
instance from the container:
$rdap = app(Rdap::class);
To get information about a domain, call domain()
.
$domain = $rdap->domain('google.com'); // returns an instance of `Spatie\Rdap\Responses\DomainResponse`
If you pass a non-existing domain, then the domain()
function will return null
.
On an instance of DomainResponse
you can call various methods to fetch various dates. All of these methods return an instance of Carbon\Carbon
.
$domain->registrationDate();
$domain->expirationDate();
$domain->lastChangedDate();
$domain->lastUpdateOfRdapDb();
You can get all properties of a DomainResponse
using all()
.
$properties = $domain->all(); // returns an array
To know which properties get returned, take a look at this json containing the response for google.com.
Use get()
to get a specific domain property.
$domain->get('objectClassName'); // returns 'domain'
You can use dot notation to reach deeper in the properties.
$domain->get('links.0.value'); // returns 'https://rdap.verisign.com/com/v1/domain/GOOGLE.COM'
For each TLD a specific server is used to respond to domain queries. Such a server is called a "DNS server". The official list of all RDAP DNS server is available as JSON here.
The Spatie\Rdap\RdapDns
class can fetch information from that JSON file. Because all above domain methods need to search the approriate DNS server, we cache the list with available DNS servers. By default, the response will be cached for a week. You can configure this caching period in the rdap
config file.
You can resolve a configured instance from the container.
$rdapDns = app(RdapDns::class);
To get the DNS server URL for a specific domain call getServerForDomain
:
$rdapDns->getServerForDomain('google.com'); // returns "https://rdap.verisign.com/com/v1/"
Alternatively, you can use getServerForTld
and pass a TLD.
$rdapDns->getServerForDomain('com'); // returns "https://rdap.verisign.com/com/v1/"
If you pass a domain or tld that is not supported, the above methods will return null
.
To get a list of all supported TLDs, call supportedTlds
.
$rdapDns->supportedTlds(); // returns an array with all supported TLDs
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.