UNOFFICIAL Python API wrapper for dnsdumpster.com
Project description
DNSDumpster API (UNOFFICIAL)
โ ๏ธ IMPORTANT DISCLAIMER: This is an UNOFFICIAL API wrapper for dnsdumpster.com that scrapes the public website.
DNSDumpster.com offers an official API plan for commercial and heavy usage. If you need reliable, production-grade access, please consider their official API: https://dnsdumpster.com/
This unofficial wrapper should be used responsibly and in accordance with DNSDumpster's terms of service.
Overview
A Python client library for interacting with dnsdumpster.com to retrieve DNS records and subdomain information. This tool is useful for security researchers, penetration testers, and network administrators for reconnaissance purposes.
Features
- ๐ Retrieve A, MX, NS, and TXT records for a domain
- ๐ Extract subdomain information
- ๐บ๏ธ Download network mapping images
- ๐ Export results to Excel format
- ๐ฏ Clean, type-hinted API
- โ Comprehensive test coverage
- ๐ Full backward compatibility
Installation
From PyPI (Recommended)
pip install dnsdumpster
From GitHub
pip install git+https://github.com/PaulSec/API-dnsdumpster.com.git
From Source (Development)
# Clone the repository
git clone https://github.com/PaulSec/API-dnsdumpster.com
cd API-dnsdumpster.com
# Install in development mode
pip install -e .
# Install development dependencies
pip install -r requirements-dev.txt
Quick Start
from dnsdumpster.DNSDumpsterAPI import DNSDumpsterAPI
# Initialize the API
api = DNSDumpsterAPI(verbose=True)
# Search for a domain
results = api.search('example.com')
# Access the results
print(f"Domain: {results['domain']}")
print(f"DNS Records: {results['dns_records']['dns']}")
print(f"MX Records: {results['dns_records']['mx']}")
print(f"NS Records: {results['dns_records']['ns']}")
print(f"TXT Records: {results['dns_records']['txt']}")
Usage Examples
Basic Domain Lookup
from dnsdumpster.DNSDumpsterAPI import DNSDumpsterAPI
api = DNSDumpsterAPI()
results = api.search('microsoft.com')
# Print all A records (subdomains)
for record in results['dns_records']['dns']:
print(f"{record['host']} - {record['ip']} - {record['country']}")
Save Network Map Image
import base64
results = api.search('example.com')
if results['image_data']:
with open('network_map.png', 'wb') as f:
f.write(base64.b64decode(results['image_data']))
print(f"Network map saved! URL: {results['image_url']}")
Export to Excel
import base64
results = api.search('example.com')
if results['xls_data']:
with open('results.xlsx', 'wb') as f:
f.write(base64.b64decode(results['xls_data']))
print("Excel file saved!")
Using Custom Session
import requests
from dnsdumpster.DNSDumpsterAPI import DNSDumpsterAPI
# Create custom session with proxy
session = requests.Session()
session.proxies = {
'http': 'http://proxy.example.com:8080',
'https': 'https://proxy.example.com:8080',
}
api = DNSDumpsterAPI(session=session)
results = api.search('example.com')
Error Handling
from dnsdumpster.DNSDumpsterAPI import (
DNSDumpsterAPI,
DNSDumpsterAPIError,
DNSDumpsterRequestError,
DNSDumpsterParseError
)
api = DNSDumpsterAPI()
try:
results = api.search('example.com')
except DNSDumpsterRequestError as e:
print(f"Network error: {e}")
except DNSDumpsterParseError as e:
print(f"Parsing error: {e}")
except DNSDumpsterAPIError as e:
print(f"API error: {e}")
API Response Structure
The search() method returns a dictionary with the following structure:
{
'domain': 'example.com',
'dns_records': {
'dns': [ # A Records (subdomains)
{
'host': 'subdomain.example.com',
'ip': '192.0.2.1',
'reverse_dns': 'reverse.dns.com',
'asn': 'ASN:12345',
'asn_name': 'Provider Name',
'country': 'United States',
'subnet': '192.0.2.0/24',
'open_services': '80, 443',
# Backward compatibility keys:
'domain': 'subdomain.example.com',
'as': 'ASN:12345',
'provider': 'Provider Name'
}
],
'mx': [ # MX Records
{
'priority': '10',
'server': 'mail.example.com',
'ip': '198.51.100.1',
'reverse_dns': 'mail.reverse.com',
'asn': 'ASN:23456',
'asn_name': 'Mail Provider',
'country': 'Germany',
'subnet': '198.51.100.0/24'
}
],
'ns': [ # NS Records
{
'nameserver': 'ns1.example.com',
'ip': '203.0.113.1',
'reverse_dns': 'ns1.reverse.com',
'asn': 'ASN:34567',
'asn_name': 'DNS Provider',
'country': 'United Kingdom',
'subnet': '203.0.113.0/24'
}
],
'txt': [ # TXT Records
'v=spf1 include:_spf.example.com ~all',
'google-site-verification=abcdef123456'
],
'host': [] # Alias for NS records (backward compatibility)
},
'image_data': b'base64_encoded_image_bytes', # or None
'image_url': 'https://dnsdumpster.com/static/map/example.com.png',
'xls_data': b'base64_encoded_excel_bytes', # or None
'xls_url': 'https://dnsdumpster.com/static/xlsx/example-uuid.xlsx'
}
Development
Setup Development Environment
# Clone the repository
git clone https://github.com/PaulSec/API-dnsdumpster.com
cd API-dnsdumpster.com
# Create virtual environment
python -m venv venv
source venv/bin/activate # On Windows: venv\Scripts\activate
# Install dependencies
pip install -r requirements.txt
pip install -r requirements-dev.txt
# Install pre-commit hooks (optional)
pip install pre-commit
pre-commit install
Running Tests
# Run all tests
pytest
# Run with coverage
pytest --cov=dnsdumpster --cov-report=html
# Run specific test file
pytest tests/test_parsing.py
# Run with verbose output
pytest -v
# Run specific test
pytest tests/test_parsing.py::TestRetrieveResults::test_retrieve_results_basic
Code Quality
# Format code with black
black dnsdumpster/ tests/
# Sort imports
isort dnsdumpster/ tests/
# Lint with flake8
flake8 dnsdumpster/ tests/
# Type checking with mypy
mypy dnsdumpster/
# Run all quality checks
black dnsdumpster/ tests/ && isort dnsdumpster/ tests/ && flake8 dnsdumpster/ tests/ && mypy dnsdumpster/
Project Structure
API-dnsdumpster.com/
โโโ dnsdumpster/ # Main package
โ โโโ __init__.py
โ โโโ DNSDumpsterAPI.py # Main API class
โ โโโ API_example.py # Usage example
โ โโโ requirements.txt
โโโ tests/ # Test suite
โ โโโ __init__.py
โ โโโ conftest.py # Pytest fixtures
โ โโโ test_parsing.py # Unit tests
โ โโโ test_integration.py # Integration tests
โโโ .github/
โ โโโ workflows/ # CI/CD workflows
โ โโโ tests.yml
โ โโโ publish.yml
โโโ requirements.txt # Production dependencies
โโโ requirements-dev.txt # Development dependencies
โโโ setup.py # Package configuration
โโโ README.md
โโโ LICENSE
Contributing
We welcome contributions! Here's how you can help:
Reporting Issues
- Use GitHub Issues to report bugs
- Include Python version, OS, and error messages
- Provide minimal reproducible examples
Submitting Pull Requests
- Fork the repository
- Create a feature branch (
git checkout -b feature/amazing-feature) - Make your changes
- Add tests for new functionality
- Ensure all tests pass (
pytest) - Run code quality checks (
black,flake8,mypy) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
Coding Guidelines
- Follow PEP 8 style guide
- Add type hints to all functions
- Write docstrings for public methods
- Maintain backward compatibility
- Keep test coverage above 80%
- Update documentation for new features
Testing Instructions
Unit Tests
Test individual parsing methods without network calls:
pytest tests/test_parsing.py -v
Integration Tests
Test the full API workflow with mocked HTTP responses:
pytest tests/test_integration.py -v
Coverage Report
pytest --cov=dnsdumpster --cov-report=term-missing
CI/CD
The project uses GitHub Actions for:
- Testing: Runs on every push and PR across Python 3.8, 3.9, 3.10, 3.11, 3.12
- Linting: Code quality checks with flake8 and mypy
- Publishing: Automatic PyPI deployment on tagged releases
License
This project is licensed under the MIT License - see the LICENSE file for details.
Disclaimer
This is an unofficial tool and is not affiliated with or endorsed by dnsdumpster.com. Use responsibly and in accordance with the target website's terms of service and robots.txt. The authors are not responsible for misuse of this tool.
Support
- ๐ง For bugs and feature requests, use GitHub Issues
- ๐ฌ For general questions, start a GitHub Discussion
- ๐ฆ Follow the author on Twitter: @PaulWebSec
Changelog
Version 0.10 (Current)
- Complete code refactoring with type hints
- Improved error handling with custom exceptions
- Comprehensive test suite with pytest
- Better documentation and examples
- CI/CD with GitHub Actions
- Full backward compatibility maintained
Previous Versions
See CHANGELOG.md for full version history.
Acknowledgments
- Original author: PaulSec
- Contributors: See CONTRIBUTORS.md
- DNSDumpster.com for providing the service
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dnsdumpster-0.11.0.tar.gz.
File metadata
- Download URL: dnsdumpster-0.11.0.tar.gz
- Upload date:
- Size: 19.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b74d96c106ec044ef6ab56fbcedf439d838144808849bfdf7f48f7b3f8d87f6c
|
|
| MD5 |
8ae73a465470ec6d18119f819cfb7fa1
|
|
| BLAKE2b-256 |
e6e524856ee7e00e70a93564118be4e930ed4d759d9c976eef7d0c9bb118bdc2
|
File details
Details for the file dnsdumpster-0.11.0-py3-none-any.whl.
File metadata
- Download URL: dnsdumpster-0.11.0-py3-none-any.whl
- Upload date:
- Size: 12.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
688dc5b5672d992e54797b68db4b1b3bc899384542bfef774b8f1853b2bd069f
|
|
| MD5 |
c37a9e0df713d53081f2d3d8fe14c1a5
|
|
| BLAKE2b-256 |
79c1625f4ca154831ece0db2df85f06f0aaca72213a777c8b17b2c8da0a19fb6
|