Skip to main content

GoDaddy DNS provider extension for npmctl.

Project description

npmctl-godaddy

GoDaddy DNS provider plugin for npmctl

Extend npmctl with GoDaddy-backed DNS record management for declarative workflows, provider discovery, and DNS-aware automation.

PyPI version Python versions CI Apache 2.0 License

npmctl-godaddy package hits npmctl-godaddy downloads

npmctl architecture infographic

npmctl-godaddy is the GoDaddy DNS provider package for npmctl. Install it when you want desired-state DNS records or DNS diagnostics to resolve through GoDaddy instead of using only the base npmctl package.

Supported Python Versions

npmctl-godaddy supports Python 3.10, 3.11, 3.12, 3.13, and 3.14.

Why npmctl-godaddy

  • Adds GoDaddy DNS provider discovery to npmctl
  • Lets DNS workflows live beside proxy and certificate desired state
  • Keeps GoDaddy API keys out of the core CLI package
  • Supports operator diagnostics through npmctl dns doctor
  • Documents GoDaddy's record-set replacement behavior for safer automation

FAQ

What is npmctl-godaddy?

Answer: npmctl-godaddy is a plugin package that teaches npmctl how to talk to the GoDaddy Domains API for DNS record operations and DNS provider diagnostics.

When do I need npmctl-godaddy?

Answer: You need npmctl-godaddy when your npmctl workflow includes GoDaddy-managed DNS records or when you want npmctl to validate GoDaddy DNS connectivity and credentials.

Does npmctl-godaddy work without npmctl?

Answer: No. npmctl-godaddy is an extension package for npmctl, not a standalone CLI.

Can npmctl-godaddy set DNS records?

Answer: Yes. The GoDaddy provider supports declarative A, AAAA, CNAME, TXT, MX, SRV, and CAA writes. MX records require priority. Its DNS mutation endpoint replaces all records for one {type, name} pair, so preserve existing values when managing multi-value records.

What credentials are required?

Answer: GoDaddy API access requires GODADDY_API_KEY and GODADDY_API_SECRET. Account protection, domain locks, or product eligibility can still block DNS mutations even when credentials are valid.

Install

Install the base CLI and the GoDaddy provider package together:

pipx install npmctl
pipx inject npmctl npmctl-godaddy
npmctl plugins list

With uv:

uv tool install npmctl
uv tool install npmctl-godaddy
npmctl plugins list

Inside a virtual environment:

python -m venv .venv
. .venv/bin/activate
python -m pip install npmctl npmctl-godaddy
npmctl plugins list

Configure GoDaddy

Set the required environment variables:

export GODADDY_API_KEY=your-api-key
export GODADDY_API_SECRET=your-api-secret

Optional for tests or alternate endpoints:

export GODADDY_API_BASE_URL=https://api.godaddy.com

Verify Plugin Discovery

Check that npmctl can discover the provider:

npmctl plugins list
npmctl dns doctor --provider godaddy

Minimal DNS Workflow

Once the provider is installed and configured, npmctl can validate, plan, apply, or diagnose GoDaddy-backed DNS behavior through the base CLI:

npmctl validate desired-state/dns.yaml
npmctl plan desired-state/dns.yaml --owner site-a
npmctl apply desired-state/dns.yaml --owner site-a
npmctl dns providers
npmctl dns zones --provider godaddy
npmctl dns records --provider godaddy --zone example.com

GoDaddy API Surface

The provider follows the GoDaddy Domains API DNS record surface:

  • GET /v1/domains: discover domains in the account.
  • GET /v1/domains/{domain}/records: list all DNS records for one domain.
  • GET /v1/domains/{domain}/records/{type}/{name}: list records for one type and name.
  • PUT /v1/domains/{domain}/records/{type}/{name}: replace the full record set for one type and name.
  • DELETE /v1/domains/{domain}/records/{type}/{name}: delete records for one type and name.

Programmatic Record Operations

create_record() is a convenience wrapper that replaces a {type, name} pair with one record. Use replace_records() when preserving multiple values for the same record name and type:

from npmctl_godaddy import GoDaddyClient, GoDaddyConfig

client = GoDaddyClient(GoDaddyConfig.from_env())
client.create_record("example.com", type="A", name="www", value="192.0.2.10", ttl=600)
client.replace_records(
    "example.com",
    type="CNAME",
    name="app",
    records=[{"data": "target.example.net", "ttl": 600}],
)
client.delete_records("example.com", type="A", name="www")

Safety Notes

  • GoDaddy PUT replaces all records for the selected {type, name} pair.
  • Account-level domain locks, premium DNS status, protection settings, or product eligibility may block API changes even when credentials are valid.
  • Use least-privilege keys where available and avoid broad automation over unrelated domains.
  • Use npmctl owner metadata for desired DNS records so apply remains owner-scoped.

More Documentation

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

npmctl_godaddy-0.3.10.tar.gz (6.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

npmctl_godaddy-0.3.10-py3-none-any.whl (8.8 kB view details)

Uploaded Python 3

File details

Details for the file npmctl_godaddy-0.3.10.tar.gz.

File metadata

  • Download URL: npmctl_godaddy-0.3.10.tar.gz
  • Upload date:
  • Size: 6.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for npmctl_godaddy-0.3.10.tar.gz
Algorithm Hash digest
SHA256 50c84a4344650f84943db77bb1ba6ef5608f054c833c04b8d69066585d3b2265
MD5 26f509858c3a4f0d6da09cc75d56fdd0
BLAKE2b-256 79e64b69782c1ba6ab4429cf15bc09739d43c797dd8f37bba2b5274b397d531a

See more details on using hashes here.

Provenance

The following attestation bundles were made for npmctl_godaddy-0.3.10.tar.gz:

Publisher: release.yml on groupsum/npmctl

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file npmctl_godaddy-0.3.10-py3-none-any.whl.

File metadata

File hashes

Hashes for npmctl_godaddy-0.3.10-py3-none-any.whl
Algorithm Hash digest
SHA256 d7edad9e3fa37deed3141bf7e65334144239dd681e7246c02b7e38be3f5ae65e
MD5 8b91017f94aabd683d988e80fbcbfcb5
BLAKE2b-256 00c70f40b6140f8738cb81dd7154cd47db69c01b52569c6feead875a85e42345

See more details on using hashes here.

Provenance

The following attestation bundles were made for npmctl_godaddy-0.3.10-py3-none-any.whl:

Publisher: release.yml on groupsum/npmctl

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page