mirror of
https://github.com/danog/dns.git
synced 2025-01-23 05:51:11 +01:00
48 lines
2.0 KiB
PHP
48 lines
2.0 KiB
PHP
<?php
|
|
|
|
namespace Amp\Dns;
|
|
|
|
interface Resolver {
|
|
/**
|
|
* Resolve a hostname name to an IP address
|
|
* [hostname as defined by RFC 3986]
|
|
*
|
|
* Upon success the returned promise resolves to an indexed array of the form:
|
|
*
|
|
* [string $recordValue, int $type, int $ttl]
|
|
*
|
|
* A null $ttl value indicates the DNS name was resolved from the cache or the
|
|
* local hosts file.
|
|
* $type being one constant from Amp\Dns\Record
|
|
*
|
|
* Options:
|
|
*
|
|
* - "server" | string Custom DNS server address in ip or ip:port format (Default: 8.8.8.8:53)
|
|
* - "timeout" | int DNS server query timeout (Default: 3000ms)
|
|
* - "hosts" | bool Use the hosts file (Default: true)
|
|
* - "reload_hosts" | bool Reload the hosts file (Default: false), only active when no_hosts not true
|
|
* - "cache" | bool Use local DNS cache when querying (Default: true)
|
|
* - "types" | array Default: [Record::A, Record::AAAA] (only for resolve())
|
|
* - "recurse" | bool Check for DNAME and CNAME records (always active for resolve(), Default: false for query())
|
|
*
|
|
* If the custom per-request "server" option is not present the resolver will
|
|
* use the first nameserver in /etc/resolv.conf or default to Google's public
|
|
* DNS servers on Windows or if /etc/resolv.conf is not found.
|
|
*
|
|
* @param string $name The hostname to resolve
|
|
* @param array $options
|
|
* @return \Amp\Promise
|
|
* @TODO add boolean "clear_cache" option flag
|
|
*/
|
|
public function resolve($name, array $options = []);
|
|
|
|
/**
|
|
* Query specific DNS records.
|
|
*
|
|
* @param string $name Unlike resolve(), query() allows for requesting _any_ name (as DNS RFC allows for arbitrary strings)
|
|
* @param int|int[] $type Use constants of Amp\Dns\Record
|
|
* @param array $options @see resolve documentation
|
|
* @return \Amp\Promise
|
|
*/
|
|
public function query($name, $type, array $options = []);
|
|
} |