No project description provided
Project description
Python DNS Client
A simple dns client library for send queries.
- null-dependency
- threadsafe
- type hints
Install:
# from pypi.org
pip install dns-client
# latest commit
pip install git+https://github.com/s3rgeym/python-dns-client.git
Examples:
In [1]: from dns_client import DNSClient, RecordType
# use cloudflare to resolve dns queries
In [2]: client = DNSClient('1.1.1.1')
# get host ip address
In [3]: client.gethostaddr('yandex.ru')
Out[3]: '5.255.255.77'
# get name servers
In [4]: client.get_name_servers('yandex.ru')
Out[4]: ['ns2.yandex.ru', 'ns1.yandex.ru']
# each value is string
In [5]: client.query('www.linux.org')
Out[5]:
[Answer(name='www.linux.org', qtype=<RecordType.A: 1>, qclass=<RecordClass.IN: 1>, ttl=300, value='172.67.73.26'),
Answer(name='www.linux.org', qtype=<RecordType.A: 1>, qclass=<RecordClass.IN: 1>, ttl=300, value='104.26.15.72'),
Answer(name='www.linux.org', qtype=<RecordType.A: 1>, qclass=<RecordClass.IN: 1>, ttl=300, value='104.26.14.72')]
In [6]: client.query('www.linux.org', RecordType.AAAA)
Out[6]:
[Answer(name='www.linux.org', qtype=<RecordType.AAAA: 28>, qclass=<RecordClass.IN: 1>, ttl=300, value='2606:4700:20::681a:f48'),
Answer(name='www.linux.org', qtype=<RecordType.AAAA: 28>, qclass=<RecordClass.IN: 1>, ttl=300, value='2606:4700:20::681a:e48'),
Answer(name='www.linux.org', qtype=<RecordType.AAAA: 28>, qclass=<RecordClass.IN: 1>, ttl=300, value='2606:4700:20::ac43:491a')]
# but for MX each value is tuple where first element is priority
In [7]: client.query('yandex.ru', RecordType.MX)
Out[7]: [Answer(name='yandex.ru', qtype=<RecordType.MX: 15>, qclass=<RecordClass.IN: 1>, ttl=1078, value=(10, 'mx.yandex.ru'))]
In [8]: client.query('ya.ru', RecordType.TXT)
Out[8]:
[Answer(name='ya.ru', qtype=<RecordType.TXT: 16>, qclass=<RecordClass.IN: 1>, ttl=1200, value='_globalsign-domain-verification=dHoe580bPQ-lfi_vh-BEIwB4NAtUwURIzrzsivByVL'),
Answer(name='ya.ru', qtype=<RecordType.TXT: 16>, qclass=<RecordClass.IN: 1>, ttl=1200, value='e1c8e4dd3d13fad0dd9e8ed54a1813ececd3d5412fb16c4ed2c0612332950fe'),
Answer(name='ya.ru', qtype=<RecordType.TXT: 16>, qclass=<RecordClass.IN: 1>, ttl=1200, value='_globalsign-domain-verification=xUUDG4u7Zo56EmmFewz7Y4UK3MfAU7QSjAgBsy0w6q'),
Answer(name='ya.ru', qtype=<RecordType.TXT: 16>, qclass=<RecordClass.IN: 1>, ttl=1200, value='v=spf1 redirect=_spf.yandex.ru'),
Answer(name='ya.ru', qtype=<RecordType.TXT: 16>, qclass=<RecordClass.IN: 1>, ttl=1200, value='google-site-verification=SVTEeUiCU4KV-5qGw4o4JPok7mfsP8NtQTIdN6tt6Nw'),
Answer(name='ya.ru', qtype=<RecordType.TXT: 16>, qclass=<RecordClass.IN: 1>, ttl=1200, value='_globalsign-domain-verification=eLi0_-xATuNmRfuTIX8VQIvgfyi7Od7Hph4V0yNisF')]
In [9]: adguard_client = DNSClient('94.140.14.14')
# unknown dns record types and some other returns raw bytes
In [10]: adguard_client.query('www.linux.org', RecordType.ANY)
Out[10]: [Answer(name='www.linux.org', qtype=<RecordType.UNKNOWN: -1>, qclass=<RecordClass.IN: 1>, ttl=3280, value=b'\x07RFC8482\x00')]
# exceptions
# axfr queries are useful for domain scanning
In [11]: adguard_client.query('www.linux.org', RecordType.AXFR)
---------------------------------------------------------------------------
DNSError Traceback (most recent call last)
Cell In[11], line 1
...
DNSError: dns server returns bad response code: 0x05
# you can get entire response instead list of answers
In [12]: adguard_client.get_response_query('www.linux.org', RecordType.AXFR)
Out[12]: Packet(header=Header(id=36118, is_response=True, opcode=<OpCode.QUERY: 0>, authoritative_answer=False, truncated=False, recursion_desired=True, recursion_available=False, reserved=2, response_code=<ResponseCode.REFUSED: 5>, num_questions=1, num_answers=0, num_authorities=0, num_additionals=0), questions=[Question(name='www.linux.org', qtype=<RecordType.AXFR: 252>, qclass=<RecordClass.IN: 1>)], answers=[])
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
dns-client-0.1.0.tar.gz
(9.6 kB
view details)
Built Distribution
File details
Details for the file dns-client-0.1.0.tar.gz
.
File metadata
- Download URL: dns-client-0.1.0.tar.gz
- Upload date:
- Size: 9.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 422c39d36af771467cdd56612cc2e4cb624e25180a3dc7af141ca2d5a173cb29 |
|
MD5 | c43bdf8f5699279268d78597d67a7c7b |
|
BLAKE2b-256 | d9d089ab6dd7966866155e00a280c6293c5cd7248d64b6c8bf00a1bbaec09bcb |
File details
Details for the file dns_client-0.1.0-py3-none-any.whl
.
File metadata
- Download URL: dns_client-0.1.0-py3-none-any.whl
- Upload date:
- Size: 9.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.7
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | fae9bdd952c42c6c19dda958ed5da6ebe67aed73b870e6bffd1dedbac2d646ce |
|
MD5 | 4a01eb6e15d0ba504292856c0f565b5d |
|
BLAKE2b-256 | 38ac2e6ece3de42c26e8c7bbc2d7fa78665c6d62467b96e38c145a2aba025d05 |