Skip to content

dns_get_record() does not support a request to a specific NS server to determine the NS records of a domain. #9924

Open
@13ilya-old

Description

@13ilya-old

Description

The task is to determine. that my client, which is the owner of the domain, has specified the correct NS records with the registrar, and I can accept it for service on my dns server.

Many people mistakenly think that it is enough to check the NS-record of the domain, but it is not so!
To make things worse, almost all DNS-servers, after accepting a domain for service, create the same NS-records, so that the client could register subdomains (www, mail, etc.). But this NS record only affects subdomains or child domains, not the domain itself.
For example, I will take the domain umi.ru (it is very difficult to find a domain where these records are different).
dig +short NS umi.ru or var_export(dns_get_record('umi.ru', DNS_NS));

ns1.umi.ru.
ns2.umi.ru.
ns3.umi.ru.
ns4.umi.ru.

These NS records are specified by the DNS server, not the domain registrar, and affect subdomains, but not the domain itself.

To get the exact NS records that are specified at the domain registrar. and that respond directly to the domain, that is, to which DNS-server to apply when a request comes to this domain, you need to do the following.
1 Define the parent zone (domain level above) for umi.ru parent zone ru.
2 Get the list of NS-servers of the parent zone.
dig +short NS ru or var_export(dns_get_record('ru', DNS_NS));

a.dns.ripn.net.
b.dns.ripn.net.
d.dns.ripn.net.
e.dns.ripn.net.
f.dns.ripn.net.

3 Get the NS record from exactly one of these servers (authoritative servers).
dig NS @a.dns.ripn.net umi.ru or ... but there is no such function in php and you can't make this request through dns_get_record(). :-(

.......................................................................................
UMI.RU.                 345600 IN NS ns1.umi.RU.
UMI.RU.                 345600 IN NS ns2.umi.RU.
UMI.RU.                 345600 IN NS ns3.umi.RU.
.......................................................................................

Registry and order does not matter, but these 3 NS records prescribed, rather than 4 as above, the registrar of the domain and it is them that I need to get and check to be sure that I can bind this domain to my dns-server.
Most have the same, but it is not always the case and need to get the latter.

I need to be able to get them in php without calling exec('dig NS @a.dns.ripn.net umi.ru', $out, $exit); var_export($out);.

Metadata

Metadata

Assignees

No one assigned

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions