Open
Conversation
Cleaned hidden or bidirectional Unicode text
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
Motivation
The existing "hetzner" provider targets the legacy DNS API.
With the migration to the Hetzner Console (Cloud) DNS,
updates against the old endpoint return HTTP 422.
This provider implements support for the new RRSet-based
Hetzner Cloud DNS API.
This implementation focuses on the native ddclient DynDNS use case (A/AAAA),
which is a subset of the more comprehensive Hetzner DNS plugin attempted in upstream
pull request #5091 but not merged due to scope and maintenance considerations.
This provider is lightweight and specifically targets Dynamic DNS (DynIP)
updates using the Hetzner Cloud DNS API and integrates with the native
AccountFactory without introducing a full DNS management UI.
See: #5091 for reference.
Tested Scenarios
Environment:
Test cases:
✔ Initial IPv4 update
HetznerCloud: A silonet.org -> <IPv4>✔ Initial IPv6 update
HetznerCloud: AAAA silonet.org -> <IPv6>✔ No unnecessary updates
not modified✔ Error case validation
✔ Multiple account setup
The provider integrates cleanly with the native AccountFactory loader and
requires no additional GUI model changes.
Uses Python requests for API communication.