A very simple python client used to update the IP address in A records for GoDaddy managed domains.
Project description
GoDaddyPy
Python library useful for updating DNS settings through the GoDaddy v1 API.
Migrated from: https://github.com/eXamadeus-zz/godaddypy
Concept originated from observerss’ pygodaddy @ https://github.com/observerss/pygodaddy.
Setup
First, go to https://developer.godaddy.com/keys/ and request a production API key and secret.
Note: Sometimes the production API keys don’t seem to work correctly. Just delete it and request another one.
Second, install GoDaddyPy with pip.
$ pip install godaddypy
GoDaddyPy supports three methods for providing your credentials to the library, which are honored in the following order:
Passing them directly to the Account object
Setting the GODADDY_API_KEY and GODADDY_API_SECRET environment variables
Storing them in a credentials.yml file
For convenience, a configuration tool has been provided that can be run from your terminal or in Python. This tool will prompt for your API key and secret, and store them in a config file in your home directory following the XDG Base Directory specification. I have only tested this on Mac, but it should also work on Linux. I recommend env vars for Windows and/or CI/CD.
$ python -m godaddypy
>>> from godaddypy import Account
>>> acct = Account.configure()
Enter GoDaddy API Key [None]: example_key
Enter GoDaddy API Secret [None]: example_secret
>>> account = Account()
>>> account._config
Configuration(key='example_key', secret='example_secret')
Examples
Also see /examples for more examples.
>>> from godaddypy import Client, Account
>>>
>>> my_acct = Account(api_key='PUBLIC_KEY', api_secret='SECRET_KEY')
>>> client = Client(my_acct)
>>>
>>> # Or if you want to use a delegate...
>>> delegate_acct = Account(api_key='PUBLIC_KEY', api_secret='SECRET_KEY', delegate='DELEGATE_ID')
>>> delegate_client = Client(delegate_acct)
>>>
>>> client.get_domains()
['domain1.example', 'domain2.example']
>>>
>>> client.get_records('domain1.example', record_type='A')
[{'name': 'dynamic', 'ttl': 3600, 'data': '1.1.1.1', 'type': 'A'}]
>>>
>>> client.update_ip('2.2.2.2', domains=['domain1.example'])
True
>>>
>>> client.get_records('domain1.example')
[{'name': 'dynamic', 'ttl': 3600, 'data': '2.2.2.2', 'type': 'A'}, {'name': 'dynamic', 'ttl': 3600, 'data': '::1',
'type': 'AAAA'},]
>>>
>>> client.get_records('apple.com', record_type='A', name='@')
[{u'data': u'1.2.3.4', u'type': u'A', u'name': u'@', u'ttl': 3600}]
>>>
>>> client.update_record_ip('3.3.3.3', 'domain1.example', 'dynamic', 'A')
True
>>>
>>> client.add_record('apple.com', {'data':'1.2.3.4','name':'test','ttl':3600, 'type':'A'})
True
>>>
>>> client.delete_records('apple.com', name='test')
True
Contributing
If you want to contribute, first off: thank you! Second, please check out the Contributing Guidelines, CONTRIBUTING.
Steps to Contribute
Pull the repository
Run make install to install the library and development dependencies
Make changes
Add tests
Open a pull request towards the main branch
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
Built Distribution
File details
Details for the file GoDaddyPy-2.5.1.tar.gz
.
File metadata
- Download URL: GoDaddyPy-2.5.1.tar.gz
- Upload date:
- Size: 11.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | db54c3a023b65f1b4b7793c8bdac0f778bb02044817df1f412c76540e2e0ae9a |
|
MD5 | ef84fc2a2628118ef82ab09d434e1115 |
|
BLAKE2b-256 | 4a30b78622c36ac91c8fbd936958c0e1cd0fea9223adf97e8f8d1228e62b4609 |
File details
Details for the file GoDaddyPy-2.5.1-py2.py3-none-any.whl
.
File metadata
- Download URL: GoDaddyPy-2.5.1-py2.py3-none-any.whl
- Upload date:
- Size: 9.7 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 22da1e2d93225e605bc150992b9ed477677f782c87e0ed3e0c47d2cbc13ece53 |
|
MD5 | 82effb8be6b3c19360e45645a6582320 |
|
BLAKE2b-256 | aeb4adc6fa27b3323e1357e574d3c6fa1fd7886c687eac011ebbd20df2789195 |