-
Notifications
You must be signed in to change notification settings - Fork 2.7k
feat(txt-registry): deprecate legacy txt-format #5172
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: master
Are you sure you want to change the base?
Conversation
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
/label tide/merge-method-squash |
/kind cleanup |
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
Signed-off-by: ivan katliarchuk <[email protected]>
which case is that one? changing owner id is not even supported by external-dns EDIT: |
I'm sorry, I'm not entirely clear on what's being asked. The issue is that I haven't discovered a reliable way to automate legacy TXT record deletions without downtimes. That's why it's not in this pull request. If someone knows how to automate this, nothing wrong to open a pull request with proposed functionality. |
this is not entirely correct, the reservation here is that the the effective solution in my opinion could be adding specific one-off mode for the external-dns or building a separate tool to aggressively scan the txt registry regardless of the changes and:
if we would like to discuss it further, it doesn't necessarily have to block this PR, which essentially is to stop adding more garbage TXT records, especially for the new users |
the txt registry has a way to force an update (see https://github.com/kubernetes-sigs/external-dns/blob/master/registry/txt.go#L217); making the solution possible. This PR deletes a part that is needed to implement the cleanup of the old-format records. |
Ok. I'll put this pr on hold. Let's get back to it in few month time. /hold |
Seems like noone suggested a solution to what was discussed here. Rationale to remove legacy TXT formats
Drawback
Two options, merging this PR or closing. I'm fine with any of them |
Regarding any bugs and potential fixes for issues like #2903 I also believe the exposure and complexity needs to be reduced.
It's a bit unfortunate that there never was an external-dns bridge release doing some sort of consistency check and then active migration to the new format. Including logging warnings about potential inconsistencies.
👀 |
Between the two I'm in favour of making a breaking change and dropping the legacy format since there's little appetite in providing an automated migration path. We've performed a migration for all our records (Google & Cloudflare providers) and though it was a bit of toil it wasn't too much effort to do so. I don't feel continuing to have both TXT formats, especially given they each have their own caveats, is sustainable to keep long term, and it's not great user experience with the current implementation |
/approve cancel |
[APPROVALNOTIFIER] This PR is NOT APPROVED This pull-request has been approved by: The full list of commands accepted by this bot can be found here.
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
/lgtm cancel |
Sorry, I thought I was on an other PR. I resumed this PR to its previous state. |
do we want to change |
Yes. Remove old format first! No option, no switch. Simply drop it from external-dns. If that is done, I strongly vote for fixing the prefix for A-records to Just my 2 cents. |
I think you misread my message.
But if we first remove old-txt format, then we will be left without 'intermediate' working option (it will introduce the 'breaking change' with 'action needed') - external-dns will manage either only A record which has So, I am more asking if we want to remove that confusion with prefix, then propose to do it first, as it will be much easier to do the refactor and migrate. But if we don't want to remove confusion, then we might just leave @frittentheke, I understand your willing to move this PR faster, but before the decision made, you may still fallback to the usage of |
No I did not misread it. The opportunity to clean up anything before the new format is LONG gone. It's out there, for quite a while and the last releases actively communicated the intend to remove the old format. We pushed ahead exactly as you said and applied In the field you will now likely encounter a wild mix of both TXT record formats. There also was plenty discussion around any potential shortcomings in #3757.
To clarify what I meant: Remove the old TXT record format for good (making any of those TXT records just meaningless garbage to external-dns). Then and only then(!) pick up on the renaming bugfix and please add an active conversion / rewrite of the prefix. This should be fairly easy then as it's not possible to have a CNAME and and A record at the same time. So a simple up-conversion is possible. But please don't give up on making things right in regard to the prefix. It's confusing and wrong naming one a |
This particular TXT registry format(old and new to an extend) has been a long-standing problem. New TXT formats have been available for a long time, and disabling the old format would not introduce a breaking change because the TXT records are just ownership records, while the new one has been standard for many versions. If we remove support for these legacy TXT records, the main concern will be dangling records from the old format, which is why we are waiting where someone would like to implement a solution to reliably do a cleanup for all combinations of the config and providers. Once again - as these are primarily ownership records, their removal should not cause any functional breakage. But as usual, it could be, that there are could be some issues or edge cases. But is difficult to predict. Users who don't require two TXT ownership records per DNS entry have viable options. They can either encrypt their TXT records, which ensures only the new format TXT record is created, or they can use the --txt-new-format-only flag to exclusively enable new records. It's important to note that, to date, not a single bug or issue related to this functionality has been identified. In both scenarios, any existing old TXT ownership records will need to be removed either manually or via proprietary scripts to prevent potential downtimes. |
There is a intermediate option - which is current TXT format(new format), introduced years back. Is there is an open issue that describes this problem, I could have a look, just need to know how to reproduce it. More important, if the prefix should be |
I'll try to have a look at this one. I remember it was mentioned in one of the issues. Just need to find and see if there is an easy fix. |
…o v0.16.1 (#667) This PR contains the following updates: | Package | Update | Change | |---|---|---| | [registry.k8s.io/external-dns/external-dns](https://github.com/kubernetes-sigs/external-dns) | minor | `v0.15.1` -> `v0.16.1` | --- ### Release Notes <details> <summary>kubernetes-sigs/external-dns (registry.k8s.io/external-dns/external-dns)</summary> ### [`v0.16.1`](https://github.com/kubernetes-sigs/external-dns/releases/tag/v0.16.1) [Compare Source](kubernetes-sigs/external-dns@v0.16.0...v0.16.1) This release fixes the breaking change introduced in v0.16.0 for Cloudflare. :warning: New features on Cloudflare, custom and regional hostnames have some known issues, see [#​5175](kubernetes-sigs/external-dns#5175) and [#​5183](kubernetes-sigs/external-dns#5183) :warning: OpenStack designate in-tree provider will be removed in the next version. There is now a [webhook provider](https://github.com/inovex/external-dns-openstack-webhook). :information_source: With v0.16.0, a new option on TXT Registry is available to use only new format ([#​4946](kubernetes-sigs/external-dns#4946)). Previous format will be removed in the next release ([#​5172](kubernetes-sigs/external-dns#5172)). #### 🐛 Bug fixes - fix(cloudflare): optional custom hostnames by [@​mrozentsvayg](https://github.com/mrozentsvayg) in kubernetes-sigs/external-dns#5146 - fix(source): pass GatewayName to config by [@​buroa](https://github.com/buroa) in kubernetes-sigs/external-dns#5169 - fix(cloudflare): infinite loop with more than 50 custom hostnames by [@​mrozentsvayg](https://github.com/mrozentsvayg) in kubernetes-sigs/external-dns#5181 #### 📦 Others - chore: update OWNERS with required config file by [@​mloiseleur](https://github.com/mloiseleur) in kubernetes-sigs/external-dns#5164 **Full Changelog**: kubernetes-sigs/external-dns@v0.16.0...v0.16.1 ### [`v0.16.0`](https://github.com/kubernetes-sigs/external-dns/releases/tag/v0.16.0) [Compare Source](kubernetes-sigs/external-dns@v0.15.1...v0.16.0) #### 💥 Breaking Changes There is a [breaking change on Cloudflare](kubernetes-sigs/external-dns#5166) with this release. It requires Cloudflare for Saas. #### 🚀 Features - feat: add dreamhost webook provider to readme ([#​5015](kubernetes-sigs/external-dns#5015)) [@​asymingt](https://github.com/asymingt) - feat: Add F5 TransportServer source ([#​4944](kubernetes-sigs/external-dns#4944)) [@​visokoo](https://github.com/visokoo) - feat(chart): allow to run tpl on `ServiceAccount` annotations ([#​4958](kubernetes-sigs/external-dns#4958)) ([#​4958](kubernetes-sigs/external-dns#4958)) [@​fcrespofastly](https://github.com/fcrespofastly) - feat(cloudflare): custom hostname and fix apex ([#​5087](kubernetes-sigs/external-dns#5087)) [@​mrozentsvayg](https://github.com/mrozentsvayg) - feat(deps): added renovate config for custom regexes ([#​4978](kubernetes-sigs/external-dns#4978)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - feat: don't discard klog logs at the highest log levels (debug and trace) ([#​4961](kubernetes-sigs/external-dns#4961)) [@​dmarkhas](https://github.com/dmarkhas) - feat(pdns): add validation for MX and SRV records ([#​4871](kubernetes-sigs/external-dns#4871)) [@​julillae](https://github.com/julillae) - feat(rfc2136): support multiple hosts ([#​4653](kubernetes-sigs/external-dns#4653)) [@​Jeremy-Boyle](https://github.com/Jeremy-Boyle) - feat(service): listen to endpoint changes ([#​5085](kubernetes-sigs/external-dns#5085)) [@​dmarkhas](https://github.com/dmarkhas) - feat(source): allow to register all pods and their associated PTR record ([#​4782](kubernetes-sigs/external-dns#4782)) [@​foyerunix](https://github.com/foyerunix) - feat(txt-registry): add option to use only new format ([#​4946](kubernetes-sigs/external-dns#4946)) [@​malpou](https://github.com/malpou) #### 🐛 Bug fixes - fix(aes-encryption): support plain txt and url safe base64 strings ([#​4980](kubernetes-sigs/external-dns#4980)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - fix(aws-provider): ListTagsForResource incorrect zone-id handling ([#​5029](kubernetes-sigs/external-dns#5029)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - fix(chart): non-string types on svcaccount annotations ([#​5067](kubernetes-sigs/external-dns#5067)) [@​hjoshi123](https://github.com/hjoshi123) - fix(chart): regression with affinity.nodeAffinity getting ignored ([#​5046](kubernetes-sigs/external-dns#5046)) [@​mkhpalm](https://github.com/mkhpalm) - fix(chart): update rbac for F5 transportserver source ([#​5066](kubernetes-sigs/external-dns#5066)) ([#​5066](kubernetes-sigs/external-dns#5066)) [@​visokoo](https://github.com/visokoo) - fix(cloudflare): add more descriptive log message ([#​5047](kubernetes-sigs/external-dns#5047)) [@​AndrewCharlesHay](https://github.com/AndrewCharlesHay) - fix(cloudflare): use softerror on internal server error with api ([#​4931](kubernetes-sigs/external-dns#4931)) [@​vishuvenu](https://github.com/vishuvenu) - fix(dedup): records with different type are not duplicates ([#​4889](kubernetes-sigs/external-dns#4889)) [@​jtszalay](https://github.com/jtszalay) - fix(docs): aws tutorial broken internal markdown links ([#​5036](kubernetes-sigs/external-dns#5036)) [@​strophy](https://github.com/strophy) - fix: do not merge CNAME with multiple targets ([#​4856](kubernetes-sigs/external-dns#4856)) [@​dtuck9](https://github.com/dtuck9) - fix(f5-virtualserver): skip endpoint creation when VirtualServer is not ready ([#​4996](kubernetes-sigs/external-dns#4996)) [@​mikejoh](https://github.com/mikejoh) - fix(godaddy): Handle missing Retry-After header gracefully ([#​4866](kubernetes-sigs/external-dns#4866)) [@​alexstojda](https://github.com/alexstojda) - fix(oci): records with multiple IP addresses ([#​4993](kubernetes-sigs/external-dns#4993)) [@​jrosinsk](https://github.com/jrosinsk) - fix(ovh): cache refresh and duplicates processing ([#​4932](kubernetes-sigs/external-dns#4932)) [@​nmaupu](https://github.com/nmaupu) - fix(registry): handle empty targets in TXT records logging an error ([#​5149](kubernetes-sigs/external-dns#5149)) [@​saikatharryc](https://github.com/saikatharryc) - fix(source): allow ipv4-mapped ipv6 addresses ([#​4943](kubernetes-sigs/external-dns#4943)) [@​buroa](https://github.com/buroa) - fix(source): debug log on gateway target detection ([#​5096](kubernetes-sigs/external-dns#5096)) [@​drcapulet](https://github.com/drcapulet) - Fix spelling in webhook OpenAPI spec ([#​5038](kubernetes-sigs/external-dns#5038)) [@​claycooper](https://github.com/claycooper) - fix: use informer for istio gateways ([#​4522](kubernetes-sigs/external-dns#4522)) [@​woehrl01](https://github.com/woehrl01) #### 📝 Documentation - docs: add deprecation policy ([#​5053](kubernetes-sigs/external-dns#5053)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - docs: add staging images to release process ([#​5050](kubernetes-sigs/external-dns#5050)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - docs: fix typo on aws tutorial ([#​5070](kubernetes-sigs/external-dns#5070)) [@​Ileriayo](https://github.com/Ileriayo) - docs: fix typos in tutorials ([#​4969](kubernetes-sigs/external-dns#4969)) [@​mloiseleur](https://github.com/mloiseleur) - docs(Microsoft DNS): improve instructions ([#​4893](kubernetes-sigs/external-dns#4893)) [@​TomyLobo](https://github.com/TomyLobo) - docs(proposal): standartise date format ([#​5128](kubernetes-sigs/external-dns#5128)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - docs(proposal): update template with statuses ([#​5098](kubernetes-sigs/external-dns#5098)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - docs(provider): add ClouDNS to README ([#​5065](kubernetes-sigs/external-dns#5065)) [@​rwunderer](https://github.com/rwunderer) - docs(README): fix link to dev guide ([#​5116](kubernetes-sigs/external-dns#5116)) [@​masterkain](https://github.com/masterkain) - docs(registry): fix managed-record-type argument ([#​5102](kubernetes-sigs/external-dns#5102)) [@​splitice](https://github.com/splitice) - docs: update and refactor contribution part ([#​5073](kubernetes-sigs/external-dns#5073)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - ci(docs): add markdown linters and editorconfig ([#​5055](kubernetes-sigs/external-dns#5055)) [@​mloiseleur](https://github.com/mloiseleur) - Improve sources' docs to mention '--managed-record-types' ([#​4882](kubernetes-sigs/external-dns#4882)) [@​juan-vg](https://github.com/juan-vg) #### 📦 Others - add: auto label source and providers ([#​5158](kubernetes-sigs/external-dns#5158)) [@​szuecs](https://github.com/szuecs) - Add OpenStack Designate webook provider to readme ([#​5115](kubernetes-sigs/external-dns#5115)) [@​frittentheke](https://github.com/frittentheke) - chore(ci): fix and sort changelog ([#​4979](kubernetes-sigs/external-dns#4979)) [@​mloiseleur](https://github.com/mloiseleur) dependabot - chore(ci): fix failing test, upgrade to go 1.23.5 and linter to v1.63 ([#​5013](kubernetes-sigs/external-dns#5013)) [@​mloiseleur](https://github.com/mloiseleur) - chore(ci): remove too slow test ([#​5014](kubernetes-sigs/external-dns#5014)) [@​mloiseleur](https://github.com/mloiseleur) - chore(deps): bump actions/setup-python from 5.3.0 to 5.4.0 in the dev-dependencies group ([#​5041](kubernetes-sigs/external-dns#5041)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump azure/setup-helm from 4.2.0 to 4.3.0 in the dev-dependencies group ([#​5108](kubernetes-sigs/external-dns#5108)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump helm/kind-action from 1.10.0 to 1.11.0 in the dev-dependencies group ([#​4956](kubernetes-sigs/external-dns#4956)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump helm/kind-action from 1.11.0 to 1.12.0 in the dev-dependencies group ([#​4972](kubernetes-sigs/external-dns#4972)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump nosborn/github-action-markdown-cli from 3.3.0 to 3.4.0 in the dev-dependencies group ([#​5083](kubernetes-sigs/external-dns#5083)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group across 1 directory with 14 updates ([#​4976](kubernetes-sigs/external-dns#4976)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group across 1 directory with 18 updates ([#​5040](kubernetes-sigs/external-dns#5040)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group across 1 directory with 20 updates ([#​4999](kubernetes-sigs/external-dns#4999)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group across 1 directory with 21 updates ([#​5089](kubernetes-sigs/external-dns#5089)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group across 1 directory with 22 updates ([#​5062](kubernetes-sigs/external-dns#5062)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group across 1 directory with 23 updates ([#​5145](kubernetes-sigs/external-dns#5145)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group across 1 directory with 25 updates ([#​5023](kubernetes-sigs/external-dns#5023)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group across 1 directory with 5 updates ([#​4987](kubernetes-sigs/external-dns#4987)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group across 1 directory with 7 updates ([#​5125](kubernetes-sigs/external-dns#5125)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group with 20 updates ([#​5109](kubernetes-sigs/external-dns#5109)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group with 2 updates ([#​5022](kubernetes-sigs/external-dns#5022)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group with 3 updates ([#​5112](kubernetes-sigs/external-dns#5112)) [@​dependabot](https://github.com/dependabot) - chore(deps): bump the dev-dependencies group with 4 updates ([#​4988](kubernetes-sigs/external-dns#4988)) [@​dependabot](https://github.com/dependabot) - chore(docs): docs/flags.md generation ([#​4983](kubernetes-sigs/external-dns#4983)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - chore(filter-tags): pre-process filter tags ([#​5063](kubernetes-sigs/external-dns#5063)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - chore(makefile): add helper and document targets ([#​5093](kubernetes-sigs/external-dns#5093)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - chore(makefile): simplify coverage script ([#​5105](kubernetes-sigs/external-dns#5105)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - chore(provider-aws): improve canonicalHostedZone handling ([#​5031](kubernetes-sigs/external-dns#5031)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - chore(release): publish chart v1.15.2 ([#​5094](kubernetes-sigs/external-dns#5094)) [@​stevehipwell](https://github.com/stevehipwell) - chore: update maintainers/reviewers ([#​5020](kubernetes-sigs/external-dns#5020)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - chore: upgrade ExternalDNS to go 1.24 ([#​5106](kubernetes-sigs/external-dns#5106)) [@​mloiseleur](https://github.com/mloiseleur) - kustomize-v0.15.1 ([#​4966](kubernetes-sigs/external-dns#4966)) [@​Raffo](https://github.com/Raffo) - Release Helm chart for `v0.15.1` ([#​5028](kubernetes-sigs/external-dns#5028)) [@​stevehipwell](https://github.com/stevehipwell) - replace all versions to v0.15.1 ([#​4973](kubernetes-sigs/external-dns#4973)) [@​Raffo](https://github.com/Raffo) - test(cloudflare): add scenarios on submitChanges ([#​5054](kubernetes-sigs/external-dns#5054)) [@​AndrewCharlesHay](https://github.com/AndrewCharlesHay) - test(domain-filter): simple filters on domain exclusion ([#​5064](kubernetes-sigs/external-dns#5064)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) - test(provider): tags filter coverage and benchmark ([#​5060](kubernetes-sigs/external-dns#5060)) [@​ivankatliarchuk](https://github.com/ivankatliarchuk) #### New Contributors - [@​juan-vg](https://github.com/juan-vg) made their first contribution in kubernetes-sigs/external-dns#4882 - [@​dmarkhas](https://github.com/dmarkhas) made their first contribution in kubernetes-sigs/external-dns#4961 - [@​buroa](https://github.com/buroa) made their first contribution in kubernetes-sigs/external-dns#4943 - [@​fcrespofastly](https://github.com/fcrespofastly) made their first contribution in kubernetes-sigs/external-dns#4958 - [@​nmaupu](https://github.com/nmaupu) made their first contribution in kubernetes-sigs/external-dns#4932 - [@​dtuck9](https://github.com/dtuck9) made their first contribution in kubernetes-sigs/external-dns#4856 - [@​asymingt](https://github.com/asymingt) made their first contribution in kubernetes-sigs/external-dns#5015 - [@​alexstojda](https://github.com/alexstojda) made their first contribution in kubernetes-sigs/external-dns#4866 - [@​visokoo](https://github.com/visokoo) made their first contribution in kubernetes-sigs/external-dns#4944 - [@​vishuvenu](https://github.com/vishuvenu) made their first contribution in kubernetes-sigs/external-dns#4931 - [@​TomyLobo](https://github.com/TomyLobo) made their first contribution in kubernetes-sigs/external-dns#4893 - [@​strophy](https://github.com/strophy) made their first contribution in kubernetes-sigs/external-dns#5036 - [@​malpou](https://github.com/malpou) made their first contribution in kubernetes-sigs/external-dns#4946 - [@​foyerunix](https://github.com/foyerunix) made their first contribution in kubernetes-sigs/external-dns#4782 - [@​rwunderer](https://github.com/rwunderer) made their first contribution in kubernetes-sigs/external-dns#5065 - [@​Ileriayo](https://github.com/Ileriayo) made their first contribution in kubernetes-sigs/external-dns#5070 - [@​hjoshi123](https://github.com/hjoshi123) made their first contribution in kubernetes-sigs/external-dns#5067 - [@​mkhpalm](https://github.com/mkhpalm) made their first contribution in kubernetes-sigs/external-dns#5046 - [@​woehrl01](https://github.com/woehrl01) made their first contribution in kubernetes-sigs/external-dns#4522 - [@​jtszalay](https://github.com/jtszalay) made their first contribution in kubernetes-sigs/external-dns#4889 - [@​splitice](https://github.com/splitice) made their first contribution in kubernetes-sigs/external-dns#5102 - [@​drcapulet](https://github.com/drcapulet) made their first contribution in kubernetes-sigs/external-dns#5096 - [@​mrozentsvayg](https://github.com/mrozentsvayg) made their first contribution in kubernetes-sigs/external-dns#5087 - [@​frittentheke](https://github.com/frittentheke) made their first contribution in kubernetes-sigs/external-dns#5115 - [@​masterkain](https://github.com/masterkain) made their first contribution in kubernetes-sigs/external-dns#5116 - [@​renanqts](https://github.com/renanqts) made their first contribution in kubernetes-sigs/external-dns#5132 - [@​rlees85](https://github.com/rlees85) made their first contribution in kubernetes-sigs/external-dns#5111 - [@​stefaneg](https://github.com/stefaneg) made their first contribution in kubernetes-sigs/external-dns#5135 - [@​saikatharryc](https://github.com/saikatharryc) made their first contribution in kubernetes-sigs/external-dns#5149 **Full Changelog**: kubernetes-sigs/external-dns@v0.15.1...v0.16.0 </details> --- ### Configuration 📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined). 🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied. ♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about this update again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0MC4wLjAtbmV4dC4xIiwidXBkYXRlZEluVmVyIjoiNDAuMC4wLW5leHQuMSIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOlsiZGVwL21pbm9yIl19--> Reviewed-on: https://codeberg.org/JesusMtnez/homelab/pulls/667 Co-authored-by: JesusMtnez-bot <[email protected]> Co-committed-by: JesusMtnez-bot <[email protected]>
…o v0.17.0 (#712) This PR contains the following updates: | Package | Update | Change | |---|---|---| | [registry.k8s.io/external-dns/external-dns](https://github.com/kubernetes-sigs/external-dns) | minor | `v0.16.1` -> `v0.17.0` | --- ### Release Notes <details> <summary>kubernetes-sigs/external-dns (registry.k8s.io/external-dns/external-dns)</summary> ### [`v0.17.0`](https://github.com/kubernetes-sigs/external-dns/releases/tag/v0.17.0) [Compare Source](kubernetes-sigs/external-dns@v0.16.1...v0.17.0) #### Global information :information_source: On Pi Hole, support for v6 has been added. Pi Hole v5 support is deprecated and will be removed in a future version :information_source: On OVH, the provider has been heavily rewritten. New ACLs are need. See documentation and PR [#​5143](kubernetes-sigs/external-dns#5143) for details. :information_source: On IPv6, the [proposal 002](https://github.com/kubernetes-sigs/external-dns/blob/master/docs/proposal/002-internal-ipv6-handling-rollback.md) has been implemented, thanks to [@​hjoshi123](https://github.com/hjoshi123) -⚠️ In the next release, the default of this new `expose-internal-ipv6` flag will be set to false⚠️ There is a severe known issue with Active Directory ([#​5240](kubernetes-sigs/external-dns#5240)) since v0.16.0. PR to fix it ([#​5385](kubernetes-sigs/external-dns#5385)) is in review :information_source: The legacy txt-format will be removed in the next minor version ([#​5172](kubernetes-sigs/external-dns#5172)) -⚠️ There is currently no migration script to clean old style txt records. If you need it, if you think you can do it, PRs are welcome. ℹ️ A new Nomad source may be added to external-dns ([#​5284](kubernetes-sigs/external-dns#5284)) - This PR can be merged only after a review and test from real Nomad users #### 🚀 Features - feat: additional template functions by [@​matkam](https://github.com/matkam) in [#​3949](kubernetes-sigs/external-dns#3949) - feat(banner): standardize user agent and output by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5154](kubernetes-sigs/external-dns#5154) - feat(chart): Update image to v0.16.1 by [@​stevehipwell](https://github.com/stevehipwell) in [#​5201](kubernetes-sigs/external-dns#5201) - feat(cloudflare): multiple custom hostnames support by [@​mrozentsvayg](https://github.com/mrozentsvayg) in [#​5239](kubernetes-sigs/external-dns#5239) - feat(helm): allow extraArgs to also be a map enabling overrides of individual values by [@​frittentheke](https://github.com/frittentheke) in [#​5293](kubernetes-sigs/external-dns#5293) - feat: IDNA awareness in the zone finder by [@​lexisother](https://github.com/lexisother) in [#​5147](kubernetes-sigs/external-dns#5147) - feat(ovh): major rewriting of the provider by [@​rbeuque74](https://github.com/rbeuque74) in [#​5143](kubernetes-sigs/external-dns#5143) - feat(pihole): add optional support for v6 by [@​tJouve](https://github.com/tJouve) in [#​5226](kubernetes-sigs/external-dns#5226) - feat(pihole): add support for IPv6 Dual format by [@​tJouve](https://github.com/tJouve) in [#​5253](kubernetes-sigs/external-dns#5253) - feat(source): optional exclusion of unschedulable nodes by [@​Hayajiro](https://github.com/Hayajiro) in [#​5045](kubernetes-sigs/external-dns#5045) - feat(source): optional expose of nodes internal ipv6 by [@​hjoshi123](https://github.com/hjoshi123) in [#​5192](kubernetes-sigs/external-dns#5192) #### 🐛 Bug fixes - fix(aws): typo on route53 IAM by [@​tico24](https://github.com/tico24) in [#​5197](kubernetes-sigs/external-dns#5197) - fix(chart): add missing types for empty values by [@​t3mi](https://github.com/t3mi) in [#​5207](kubernetes-sigs/external-dns#5207) - fix(cloudflare): custom hostnames edge-cases causing duplicates by [@​mrozentsvayg](https://github.com/mrozentsvayg) in [#​5183](kubernetes-sigs/external-dns#5183) - fix(cloudflare): regional hostnames by [@​vflaux](https://github.com/vflaux) in [#​5175](kubernetes-sigs/external-dns#5175) - fix(Gateway API): ensure generation match by [@​davidwin93](https://github.com/davidwin93) in [#​5241](kubernetes-sigs/external-dns#5241) - fix(gateway-api): ensure to use only latest generation with HTTPRoutes by [@​kashalls](https://github.com/kashalls) in [#​5349](kubernetes-sigs/external-dns#5349) - fix(helm): added missing schema values by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5228](kubernetes-sigs/external-dns#5228) - fix(helm): update helm schema by [@​semnell](https://github.com/semnell) in [#​5297](kubernetes-sigs/external-dns#5297) - fix(log testing): re-use logger library testing functionality by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5368](kubernetes-sigs/external-dns#5368) - fix(node): logger test fixed by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5232](kubernetes-sigs/external-dns#5232) - fix(ovh): handling capitalized DNS records + prevent panic by [@​rbeuque74](https://github.com/rbeuque74) in [#​5390](kubernetes-sigs/external-dns#5390) - fix(webhook): api json object plan.Changes case by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5355](kubernetes-sigs/external-dns#5355) - fix(zonefinder): handle underscores in dns records by [@​arthlr](https://github.com/arthlr) in [#​5281](kubernetes-sigs/external-dns#5281) #### 📝 Documentation - docs(contributing): add conventional commits by [@​mloiseleur](https://github.com/mloiseleur) in [#​5333](kubernetes-sigs/external-dns#5333) - docs(proposal): externaldns api graduation to beta by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5079](kubernetes-sigs/external-dns#5079) - docs(rfc2136): fix env variable in the guideline by [@​riupie](https://github.com/riupie) in [#​5352](kubernetes-sigs/external-dns#5352) - docs(tutorials): add IONOS Cloud setup tutorial for ExternalDNS by [@​smilutinovic-ionos](https://github.com/smilutinovic-ionos) in [#​5364](kubernetes-sigs/external-dns#5364) - docs(typo): grcp → grpc by [@​octo](https://github.com/octo) in [#​5231](kubernetes-sigs/external-dns#5231) - docs: update link to Anexia webhook provider by [@​mloiseleur](https://github.com/mloiseleur) in [#​5244](kubernetes-sigs/external-dns#5244) - docs: update rfc2136 by [@​BasJ93](https://github.com/BasJ93) in [#​5325](kubernetes-sigs/external-dns#5325) #### 📦 Others - Add Yandex Cloud Webhook by [@​ismailbaskin](https://github.com/ismailbaskin) in [#​5190](kubernetes-sigs/external-dns#5190) - chore: add se for nlb, alb in thailand region by [@​xshot9011](https://github.com/xshot9011) in [#​5200](kubernetes-sigs/external-dns#5200) - chore: fix typo on txtOwnerId comment/description by [@​lanandra](https://github.com/lanandra) in [#​5351](kubernetes-sigs/external-dns#5351) - chore(ci): fix random data race failure on source/node test by [@​mloiseleur](https://github.com/mloiseleur) in [#​5268](kubernetes-sigs/external-dns#5268) - chore(ci): improve release script by [@​mloiseleur](https://github.com/mloiseleur) in [#​5394](kubernetes-sigs/external-dns#5394) - chore(ci): update linter to v2.0.2 by [@​mloiseleur](https://github.com/mloiseleur) in [#​5246](kubernetes-sigs/external-dns#5246) - chore(code-cleanup): move logic away from main.go add tests by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5222](kubernetes-sigs/external-dns#5222) - chore(code): improve some tests + re-order sources flags CLI by [@​mloiseleur](https://github.com/mloiseleur) in [#​5288](kubernetes-sigs/external-dns#5288) - chore(code-quality): added lint checks by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5318](kubernetes-sigs/external-dns#5318) - chore(code-quality): providers linter warnings fixes by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5320](kubernetes-sigs/external-dns#5320) - chore(code-quality): refactoring and linter fixes by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5374](kubernetes-sigs/external-dns#5374) - chore(code-quality): webhook increase code coverage by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5337](kubernetes-sigs/external-dns#5337) - chore(crd): use conventional paths and update controller-gen to v0.17.2 by [@​mloiseleur](https://github.com/mloiseleur) in [#​5287](kubernetes-sigs/external-dns#5287) - chore(dependencies): update toools versions by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5252](kubernetes-sigs/external-dns#5252) - chore(deps): build with go 1.24.2 by [@​mloiseleur](https://github.com/mloiseleur) in [#​5306](kubernetes-sigs/external-dns#5306) - chore(deps): bump renovatebot/github-action from 41.0.14 to 41.0.16 in the dev-dependencies group by [@​app/dependabot](https://github.com/app/dependabot) in [#​5188](kubernetes-sigs/external-dns#5188) - chore(deps): bump renovatebot/github-action from 41.0.16 to 41.0.17 in the dev-dependencies group by [@​app/dependabot](https://github.com/app/dependabot) in [#​5210](kubernetes-sigs/external-dns#5210) - chore(deps): bump the dev-dependencies group across 1 directory with 14 updates by [@​app/dependabot](https://github.com/app/dependabot) in [#​5346](kubernetes-sigs/external-dns#5346) - chore(deps): bump the dev-dependencies group across 1 directory with 14 updates by [@​app/dependabot](https://github.com/app/dependabot) in [#​5382](kubernetes-sigs/external-dns#5382) - chore(deps): bump the dev-dependencies group across 1 directory with 17 updates by [@​app/dependabot](https://github.com/app/dependabot) in [#​5238](kubernetes-sigs/external-dns#5238) - chore(deps): bump the dev-dependencies group across 1 directory with 19 updates by [@​app/dependabot](https://github.com/app/dependabot) in [#​5262](kubernetes-sigs/external-dns#5262) - chore(deps): bump the dev-dependencies group across 1 directory with 20 updates by [@​app/dependabot](https://github.com/app/dependabot) in [#​5211](kubernetes-sigs/external-dns#5211) - chore(deps): bump the dev-dependencies group across 1 directory with 21 updates by [@​mloiseleur](https://github.com/mloiseleur) in [#​5313](kubernetes-sigs/external-dns#5313) - chore(deps): bump the dev-dependencies group across 1 directory with 2 updates by [@​app/dependabot](https://github.com/app/dependabot) in [#​5247](kubernetes-sigs/external-dns#5247) - chore(deps): bump the dev-dependencies group across 1 directory with 2 updates by [@​app/dependabot](https://github.com/app/dependabot) in [#​5301](kubernetes-sigs/external-dns#5301) - chore(deps): bump the dev-dependencies group across 1 directory with 2 updates by [@​app/dependabot](https://github.com/app/dependabot) in [#​5323](kubernetes-sigs/external-dns#5323) - chore(deps): code cleanup, pkg/errors is archived by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5335](kubernetes-sigs/external-dns#5335) - chore(deps): switch to goccy yaml by [@​Raffo](https://github.com/Raffo) in [#​5292](kubernetes-sigs/external-dns#5292) - chore(deps): update linter to v2.1.x by [@​mloiseleur](https://github.com/mloiseleur) in [#​5366](kubernetes-sigs/external-dns#5366) - chore(fqdn-template): fqdn templating move to specific folder and update documentation by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5354](kubernetes-sigs/external-dns#5354) - chore(github): add a release template by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5324](kubernetes-sigs/external-dns#5324) - chore(helm): add validation for prefix and suffix and capture regression by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5250](kubernetes-sigs/external-dns#5250) - chore(openstack designate)!: remove in-tree provider by [@​mloiseleur](https://github.com/mloiseleur) in [#​5126](kubernetes-sigs/external-dns#5126) - chore(providers): rename custom TTL constants to defaultTTL by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5312](kubernetes-sigs/external-dns#5312) - chore: Release Helm chart v1.16.1 by [@​stevehipwell](https://github.com/stevehipwell) in [#​5270](kubernetes-sigs/external-dns#5270) - chore(release): updates kustomize & docs with v0.16.1 by [@​mloiseleur](https://github.com/mloiseleur) in [#​5184](kubernetes-sigs/external-dns#5184) - chore(source): code cleanup by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5304](kubernetes-sigs/external-dns#5304) - chore(webhook): bump cenkalti/backoff version by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5342](kubernetes-sigs/external-dns#5342) - test: add tests for cloudflare provider by [@​natitomattis](https://github.com/natitomattis) in [#​5248](kubernetes-sigs/external-dns#5248) - test(log): execute on multiple platforms by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5370](kubernetes-sigs/external-dns#5370) - test(log): fix random race detection by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5273](kubernetes-sigs/external-dns#5273) - test(source): cover unhappy paths by [@​linoleparquet](https://github.com/linoleparquet) in [#​5369](kubernetes-sigs/external-dns#5369) - test(source): fix data race on node_test by [@​mloiseleur](https://github.com/mloiseleur) in [#​5334](kubernetes-sigs/external-dns#5334) - test(source/pod): improve code coverage by [@​ivankatliarchuk](https://github.com/ivankatliarchuk) in [#​5378](kubernetes-sigs/external-dns#5378) - test(tlsconfig): add unit tests by [@​linoleparquet](https://github.com/linoleparquet) in [#​5381](kubernetes-sigs/external-dns#5381) - test(zone_filter): improve coverage from 66.7% to 100% by [@​upsaurav12](https://github.com/upsaurav12) in [#​5388](kubernetes-sigs/external-dns#5388) #### 📦 Docker Image docker pull registry.k8s.io/external-dns/external-dns:v0.17.0 #### New Contributors - [@​ismailbaskin](https://github.com/ismailbaskin) made their first contribution in kubernetes-sigs/external-dns#5190 - [@​lexisother](https://github.com/lexisother) made their first contribution in kubernetes-sigs/external-dns#5147 - [@​tico24](https://github.com/tico24) made their first contribution in kubernetes-sigs/external-dns#5197 - [@​t3mi](https://github.com/t3mi) made their first contribution in kubernetes-sigs/external-dns#5207 - [@​octo](https://github.com/octo) made their first contribution in kubernetes-sigs/external-dns#5231 - [@​xshot9011](https://github.com/xshot9011) made their first contribution in kubernetes-sigs/external-dns#5200 - [@​tJouve](https://github.com/tJouve) made their first contribution in kubernetes-sigs/external-dns#5226 - [@​Hayajiro](https://github.com/Hayajiro) made their first contribution in kubernetes-sigs/external-dns#5045 - [@​davidwin93](https://github.com/davidwin93) made their first contribution in kubernetes-sigs/external-dns#5241 - [@​vflaux](https://github.com/vflaux) made their first contribution in kubernetes-sigs/external-dns#5175 - [@​arthlr](https://github.com/arthlr) made their first contribution in kubernetes-sigs/external-dns#5281 - [@​semnell](https://github.com/semnell) made their first contribution in kubernetes-sigs/external-dns#5297 - [@​BasJ93](https://github.com/BasJ93) made their first contribution in kubernetes-sigs/external-dns#5325 - [@​natitomattis](https://github.com/natitomattis) made their first contribution in kubernetes-sigs/external-dns#5248 - [@​riupie](https://github.com/riupie) made their first contribution in kubernetes-sigs/external-dns#5352 - [@​lanandra](https://github.com/lanandra) made their first contribution in kubernetes-sigs/external-dns#5351 - [@​smilutinovic-ionos](https://github.com/smilutinovic-ionos) made their first contribution in kubernetes-sigs/external-dns#5364 - [@​linoleparquet](https://github.com/linoleparquet) made their first contribution in kubernetes-sigs/external-dns#5369 - [@​kashalls](https://github.com/kashalls) made their first contribution in kubernetes-sigs/external-dns#5349 - [@​matkam](https://github.com/matkam) made their first contribution in kubernetes-sigs/external-dns#3949 - [@​upsaurav12](https://github.com/upsaurav12) made their first contribution in kubernetes-sigs/external-dns#5388 **Full Changelog**: kubernetes-sigs/external-dns@v0.16.1...v0.17.0 </details> --- ### Configuration 📅 **Schedule**: Branch creation - At any time (no schedule defined), Automerge - At any time (no schedule defined). 🚦 **Automerge**: Disabled by config. Please merge this manually once you are satisfied. ♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the rebase/retry checkbox. 🔕 **Ignore**: Close this PR and you won't be reminded about this update again. --- - [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check this box --- This PR has been generated by [Renovate Bot](https://github.com/renovatebot/renovate). <!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiI0MC4xMS4xNSIsInVwZGF0ZWRJblZlciI6IjQwLjExLjE1IiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJkZXAvbWlub3IiXX0=--> Co-authored-by: JesusMtnez <[email protected]> Reviewed-on: https://codeberg.org/JesusMtnez/homelab/pulls/712 Co-authored-by: JesusMtnez-bot <[email protected]> Co-committed-by: JesusMtnez-bot <[email protected]>
Description
TODO:
Checklist
Executed on real cluster with arguments
Without change, records current and old format created
With the change. New format records created, letagcy TXT records left untouched