This Python script is designed to update DNS records for domains hosted on NameSilo, a popular domain registrar and DNS management platform. It allows you to dynamically update the IP addresses associated with your domains and subdomains whenever your WAN IP changes.
- Fetches the current WAN IP address using the
ifconfig.me
service - Retrieves and updates DNS records for specified domains from NameSilo's API
- Can automatically update all domains in your NameSilo account
- Selectively update A and/or AAAA records
- Optional SPF record updates
- Support for wildcard subdomain updates
- Robust error handling with retry mechanism
- Comprehensive logging system
- Input validation for domains and IP addresses
- Configurable through command-line arguments
- JSON-based domain configuration (optional)
- Secure API key handling through interactive prompt
Before using this script, make sure you have the following:
- Python 3.x installed on your system
- A NameSilo account with API access enabled
- Your NameSilo API key (you'll be prompted to enter it when running the script)
- Clone the repository:
git clone https://github.com/boredchilada/NamesiloDDNS.git
cd NamesiloDDNS
- Create and activate a virtual environment:
python -m venv venv
venv\Scripts\activate
python3 -m venv venv
source venv/bin/activate
- Install dependencies:
pip install -r requirements.txt
For enhanced security, the script prompts for your NameSilo API key each time it runs. This ensures that:
- Your API key is never stored in plaintext
- The key only exists in memory during script execution
- There's no risk of accidental exposure through environment variables or config files
- You maintain full control over when and how your API key is used
To update all domains in your NameSilo account:
python NamesiloDDNS.py
This will:
- Prompt you for your NameSilo API key
- Fetch all domains from your NameSilo account
- Update all subdomains for each domain
- Update both A and AAAA records by default
If you want to update only specific domains, create a JSON file (e.g., domains.json
) with your domain configuration:
{
"example.com": ["*"],
"example2.com": ["www", "mail", "dev"]
}
Then run:
python NamesiloDDNS.py -d domains.json
-d, --domains-file
: JSON file containing domains and subdomains (optional)-c, --check-ip-only
: Only check and display the current WAN IP--log-level
: Set logging level (DEBUG, INFO, WARNING, ERROR, CRITICAL)--record-types
: Comma-separated list of record types to update (default: "A,AAAA")--no-spf
: Skip updating SPF records
- Update A records for all domains in your account:
python NamesiloDDNS.py --record-types A
- Update A records for all domains, skip SPF:
python NamesiloDDNS.py --record-types A --no-spf
- Update specific domains only:
python NamesiloDDNS.py -d domains.json --record-types A
- Check current WAN IP:
python NamesiloDDNS.py -c
- Run with debug logging:
python NamesiloDDNS.py --log-level DEBUG
The script maintains a log file (namesilo_ddns.log
) containing detailed information about:
- DNS record updates
- API responses
- Errors and warnings
- IP address changes
Due to security considerations, automated/unattended operation (e.g., via cron jobs or Task Scheduler) is currently not supported. This is a deliberate design choice to prevent the storage of API keys in plaintext and reduce the risk of unauthorized access. The script requires manual input of the API key each time it runs.
If you need automated updates, consider using NameSilo's built-in DDNS service or implementing your own secure key management system.
The script includes robust error handling for:
- Network connectivity issues
- API rate limiting
- Invalid domain names
- Invalid IP addresses
- Configuration file errors
- API authentication failures
- Check the log file (
namesilo_ddns.log
) for detailed error messages - Verify your API key is valid
- Ensure your domains.json file is properly formatted (if using one)
- Check your internet connection
- Verify the domains in your configuration are active in your NameSilo account
Common issues:
- "Invalid API Key": Verify your NameSilo API key
- "Invalid Domain": Check domain format in domains.json
- "Connection Error": Check internet connectivity
- "Rate Limit": Wait before retrying (automatic retry implemented)
- "Invalid Record Type": Ensure --record-types contains only A and/or AAAA
- API key is never stored in plaintext
- The key only exists in memory during script execution
- Input is masked when entering the API key
- The script validates all inputs before processing
- HTTPS is used for all API communications
- Request timeouts prevent hanging operations
This script is released under the MIT License.
Contributions are welcome! Please feel free to submit a Pull Request.
This script is provided as-is without any warranty. Use it at your own risk. Make sure to comply with NameSilo's API usage terms and conditions.