An octoDNS provider that targets ClouDNS.
pip install octodns_cloudns
Pinning specific versions or SHAs is recommended to avoid unplanned upgrades.
# Start with the latest versions and don't just copy what's here
octodns==0.9.14
octodns_cloudns==0.0.1
# Start with the latest/specific versions and don't just copy what's here
-e git+https://git@github.com/octodns/octodns.git@9da19749e28f68407a1c246dfdf65663cdc1c422#egg=octodns
-e git+https://git@github.com/octodns/octodns_cloudns.git@ec9661f8b335241ae4746eea467a8509205e6a30#egg=octodns_cloudns
ClouDNS allows sub accounts for resellers or to lock and limit access.
For API authentication one of three options could be given exclusively:
auth_id
for a primary account id, sub_auth_id
for a sub account,
identified by id, or sub_auth_user
for sub account, identified by name.
providers:
cloudns:
class: octodns_cloudns.ClouDNSProvider
# use exactly one of auth_id, sub_auth_id, or sub_auth_user
auth_id: env/CLOUDNS_API_AUTH_ID
# sub_auth_id: env/CLOUDNS_API_SUB_AUTH_ID
# sub_auth_user: env/CLOUDNS_API_SUB_AUTH_USER
ClouDNSProvider supports A, AAAA, ALIAS, CAA, CNAME, MX, NAPTR, NS, PTR, SPF, SRV, SSHFP, URLFWD (WR), and TXT.
ClouDNSProvider DOES NOT support DNAME and LOC.
ClouDNSProvider could support DNSSEC (DS) and TLSA as well as CERT records.
ClouDNSProvider supports dynamic records only when you opt for a special (paid) plan.
See the /script/ directory for some tools to help with the development
process.
They generally follow the Script to rule them all pattern.
Most useful is ./script/bootstrap
which will create a venv and install both
the runtime and development related requirements.
It will also hook up a pre-commit hook that covers most of what's run by CI.