Skip to content
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

Add dnsendpoint CRD to Helm chart #4322

Merged
merged 6 commits into from
Apr 3, 2024

Conversation

onedr0p
Copy link
Contributor

@onedr0p onedr0p commented Mar 19, 2024

Description

Taken from https://github.com/kubernetes-sigs/external-dns/tree/master/docs/contributing/crd-source

Fixes: #2640

Checklist

  • Unit tests updated
  • End user documentation updated

Copy link

linux-foundation-easycla bot commented Mar 19, 2024

CLA Signed

The committers listed above are authorized under a signed CLA.

@k8s-ci-robot k8s-ci-robot added the cncf-cla: no Indicates the PR's author has not signed the CNCF CLA. label Mar 19, 2024
@k8s-ci-robot
Copy link
Contributor

Welcome @onedr0p!

It looks like this is your first PR to kubernetes-sigs/external-dns 🎉. Please refer to our pull request process documentation to help your PR have a smooth ride to approval.

You will be prompted by a bot to use commands during the review process. Do not be afraid to follow the prompts! It is okay to experiment. Here is the bot commands documentation.

You can also check if kubernetes-sigs/external-dns has its own contribution guidelines.

You may want to refer to our testing guide if you run into trouble with your tests not passing.

If you are having difficulty getting your pull request seen, please follow the recommended escalation practices. Also, for tips and tricks in the contribution process you may want to read the Kubernetes contributor cheat sheet. We want to make sure your contribution gets all the attention it needs!

Thank you, and welcome to Kubernetes. 😃

@k8s-ci-robot k8s-ci-robot added the needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. label Mar 19, 2024
@k8s-ci-robot
Copy link
Contributor

Hi @onedr0p. Thanks for your PR.

I'm waiting for a kubernetes-sigs member to verify that this patch is reasonable to test. If it is, they should reply with /ok-to-test on its own line. Until that is done, I will not automatically test new commits in this PR, but the usual testing commands by org members will still work. Regular contributors should join the org to skip this step.

Once the patch is verified, the new status will be reflected by the ok-to-test label.

I understand the commands that are listed here.

Instructions for interacting with me using PR comments are available here. If you have questions or suggestions related to my behavior, please file an issue against the kubernetes/test-infra repository.

@k8s-ci-robot k8s-ci-robot added size/M Denotes a PR that changes 30-99 lines, ignoring generated files. cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. and removed cncf-cla: no Indicates the PR's author has not signed the CNCF CLA. labels Mar 19, 2024
@onedr0p
Copy link
Contributor Author

onedr0p commented Mar 19, 2024

@stevehipwell as discussed in #2640 I have put this in the crds folder un-templated.

  1. Do we really need approval to include this? The CRD is usable with the application in its current state and is included in this Git repo...
  2. If no one can or will answer this question, can we just include it in the Helm chart and move on?
  3. Why do we need to wait for the CRD to be GA if it works as is? The whole project itself isn't even GA (still < 1.0.0)

If the maintainers or community decide to remove support or change the CRD, it can be updated as such from the Helm chart moving forward but I see no blockers for adding this right now.

@mloiseleur
Copy link
Contributor

/ok-to-test

@k8s-ci-robot k8s-ci-robot added ok-to-test Indicates a non-member PR verified by an org member that is safe to test. and removed needs-ok-to-test Indicates a PR that requires an org member to verify it is safe to test. labels Mar 20, 2024
@mloiseleur
Copy link
Contributor

It makes sense to me.
/lgtm

@k8s-ci-robot k8s-ci-robot added the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Mar 20, 2024
@onedr0p
Copy link
Contributor Author

onedr0p commented Mar 20, 2024

@mloiseleur should I update the chart version? If so to what version?

@mloiseleur
Copy link
Contributor

Nope. Release of the chart are done in a dedicated PR. See for instance this one.

Copy link
Contributor

@stevehipwell stevehipwell left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

@onedr0p I've added some review comments and you also need to add an entry to the CHANGELOG for each chart PR.

That said I'm not convinced that adding the CRD to the Helm chart is the right move. Firstly adding a CRD to a _Helm_chart means that by default everyone who installs the chart will also install the CRD; this makes sense where the CRD is required or likely to be required (given the constraints below), but in this case I suspect users of the CRD are in the minority. Secondly as Helm shouldn't be used for managing CRDs (it will only install them and never modify them) adding the CRD would only help the small subset of users who want to use the CRD and are putting together a quick POC (for a non-GA CRD this is even worse). On balance I think adding the CRD makes the chart experience worse for more users than better.

/hold

charts/external-dns/crds/dnsendpoint.yaml Outdated Show resolved Hide resolved
charts/external-dns/crds/dnsendpoint.yaml Outdated Show resolved Hide resolved
charts/external-dns/crds/dnsendpoint.yaml Outdated Show resolved Hide resolved
@k8s-ci-robot k8s-ci-robot added the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Mar 25, 2024
@k8s-ci-robot k8s-ci-robot removed the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Mar 25, 2024
@onedr0p
Copy link
Contributor Author

onedr0p commented Mar 25, 2024

@stevehipwell changes made.

For me, adding the DNSEndpoint CR actually improves the experience since I am using Flux and it can upgrade the CRDs (I suspect this is the same for Argo users). Having the CRD in the chart means I don't need to apply it manually or install it out-of-band of the chart itself.

@stevehipwell
Copy link
Contributor

@onedr0p I'm not saying I wont budge; what I'm saying is that adding a CRD to each cluster with ExternalDNS installed where the end user isn't aware of the --skip-crds flag or even the need for it (as this is an existing chart without any CRDs or mention of them in the primary service documentation) doesn't sound great and this is even less defensible given the assumed limited number of people using the CRD (I'm one of these although we manage all of our CRDs external to Helm).

Given the current state of play I think the next step would be to figure out if there is a requirement from enough people to have a Helm style CRD installation method (e.g. CRD chart or Job).

For me the following scenarios would warrant a reevaluation.

  • Change of Helm default CRD behaviour
  • Explicit recommendation from the core ExternalDNS maintainers to prefer the CRD method
  • End user feedback showing a significant number of users using the CRD method

@joryirving
Copy link

joryirving commented Mar 25, 2024

It feels like your reason not to include the CRD, are assuming that:

  1. Users won't read the docs, and therefore you must cater to them
  2. A limited amount of people are using the CRD.

I personally find DNSEndpoint pretty indispensable, and would be surprised it isn't commonly used, and trying to cater to the lowest common denominator on something this technical feels like the wrong way to go.

As @onedr0p already stated, other kubernetes-sigs projects have opted to include them, and IMO there's no downside if they're accidentally installed by helm anyways (if you're not going to use DNSEndpoint anyways).

If a chart installs a CRD, and they try to manually manage it externally anyways, they'll find out pretty quickly.

Either way, count me as an End user using the method that would implemented by this PR

@onedr0p
Copy link
Contributor Author

onedr0p commented Mar 26, 2024

@stevehipwell

I've read you concerns but I still really don't know what we're trying to protect against here by not merging this PR. It seems we're at a conflict at how managing Charts that contain CRDs should be handled. I and others would like the chart to handle CRDs either by the crds folder or the templated .Values.crds.enabled knob and you have stated that you do not manage any CRDs with Helm even if they are included in the chart. It seems like there is a bit of a bias in your decision here on how CRDs are handled in Helm charts which isn't great for people who want the option to have the Chart include CRDs by either of those "standard" methods.

That other idea to template the CRDs and have a .Values.crds.enabled knob like cert-manager, rook-ceph and many other charts do as well was shot down. At least using the template method (if it was defaulted to false) would get over the "unexpected CRD installed" problem you're concerned with.

I really feel like having a Job or a separate helm chart for just the CRDs is not the right way to go and this is evident by how many application and Helm Chart developers do not actually handle the CRDs this way.

Here's a list of some kubernetes-sigs applications that have Helm charts with crds included by either templated or crds directory and could not find any using the methods you purposed. Are you saying these all need to be refactored to handle CRDs differently or that they are doing it wrong? It seems to work for them, I really don't understand your concerns why it won't work here either.

From my experience most applications that have CRDs and implement a Helm chart are doing it one of those two ways and not the ways you have described. Please reconsider ❤️

@PrivatePuffin
Copy link

@stevehipwell

  • On one hand we've many projects including crds in some way. Which makes users expect projects to include their CRDs
  • On the other hand we've your recommendation not to.

I think in this case, one should have a precise and non-general reason to deviate from the standards set by nearly every other project catering a helm-chart.
Most of your arguments, seemingly, are just a rehash of previous general discussions on including crds or not and/or how Helm should handle them. This does not seem like the place, to do this all-over-again.

TLDR, unless there is a good reason against it, +1 on including the CRD as-well.

@mloiseleur
Copy link
Contributor

mloiseleur commented Mar 27, 2024

Explicit recommendation from the core ExternalDNS maintainers to prefer the CRD method

I agree that current status of CRD with Helm CLI is not convenient. CLI of Helm v3 is out there since a long time, and so, CRDs limitations are known by many Helm CLI users. At least, (other) IaC tools handle CRDs of a Chart in a more convenient way.

=> As an external-dns maintainer, I recommend to include this CRD in the Chart.

Considering that this CRD has not been modified in the last 3 years, it makes sense to me to put it in crds/ folder. I don't recommend the Job way, it can quickly become complicated for enduser with this approach.

@buroa
Copy link
Contributor

buroa commented Mar 27, 2024

I agree; it makes sense to include the CRD in the chart. So many others do it this way, and it seems it's the preferred way going forward.

@stevehipwell
Copy link
Contributor

Thanks for your feedback @mloiseleur, if the CRD is effectively a core part of ExternalDNS I see no reason not to include it. Let's get this merged so it can be included in #4357.

@onedr0p @joryirving @Ornias1993 @buroa; I'd like to point out that the argument that "other charts do something, so we should too" isn't a valid one. A lot of Helm charts lack curation and as such often implement functionality before considering the wider context and then are unable to revert the changes. Functionality should be evaluated by merit within the specific context where it's being applied.

Copy link
Contributor

@stevehipwell stevehipwell left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the PR @onedr0p.

/approve

@k8s-ci-robot k8s-ci-robot added the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Apr 3, 2024
@k8s-ci-robot
Copy link
Contributor

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: stevehipwell

The full list of commands accepted by this bot can be found here.

The pull request process is described here

Needs approval from an approver in each of these files:

Approvers can indicate their approval by writing /approve in a comment
Approvers can cancel approval by writing /approve cancel in a comment

@k8s-ci-robot k8s-ci-robot added the approved Indicates a PR has been approved by an approver from all required OWNERS files. label Apr 3, 2024
@stevehipwell
Copy link
Contributor

/unhold

@k8s-ci-robot k8s-ci-robot removed the do-not-merge/hold Indicates that a PR should not merge because someone has issued a /hold command. label Apr 3, 2024
@stevehipwell
Copy link
Contributor

/label tide/merge-method-squash

@k8s-ci-robot k8s-ci-robot added the tide/merge-method-squash Denotes a PR that should be squashed by tide when it merges. label Apr 3, 2024
@k8s-ci-robot k8s-ci-robot merged commit f5545b1 into kubernetes-sigs:master Apr 3, 2024
15 checks passed
@Skaronator
Copy link

It's great to finally see this in the helm chart. I'm finally able to use this "new" CR now.

Maybe it would make sense to enable the Custom Resource service by default?

# -- _Kubernetes_ resources to monitor for DNS entries.
sources:
- service
- ingress

Currently, the ClusterRole is not allowed to monitor the Custom Resource:

{{- if has "crd" .Values.sources }}
- apiGroups: ["externaldns.k8s.io"]
resources: ["dnsendpoints"]
verbs: ["get","watch","list"]
- apiGroups: ["externaldns.k8s.io"]
resources: ["dnsendpoints/status"]
verbs: ["*"]
{{- end }}

(thanks for pushing it though @onedr0p)

@onedr0p onedr0p deleted the patch-1 branch April 3, 2024 21:30
@onedr0p
Copy link
Contributor Author

onedr0p commented Apr 6, 2024

@Skaronator I am OK with it not being a default source in the chart as that is easy enough to override.

@PrivatePuffin
Copy link

I'd like to point out that the argument that "other charts do something, so we should too" isn't a valid one. A lot of Helm charts lack curation and as such often implement functionality before considering the wider context and then are unable to revert the changes.

I would like to point out thats essentially a strawman argument.

There is a difference between informal standards set by the industry, by big names as cert-manager, traefik, bitnami, velero etcetcetc and random other helm charts.

No one here pointed out to follow random other helm charts, but the standards set by big names including in the very same repo you're responding on.

@stevehipwell
Copy link
Contributor

@Ornias1993 you realise I maintain this chart? The informal standards you refer to sound and awful lot like cargo culting. None of the charts you referenced would be in my list of "idiomatic" charts to base out of context decisions on.

@lucasfcnunes
Copy link

lucasfcnunes commented Apr 11, 2024

Thanks for adding the CRD to the chart!

--

That other idea to template the CRDs and have a .Values.crds.enabled knob like cert-manager, rook-ceph and many other charts do as well was shot down. At least using the template method (if it was defaulted to false) would get over the "unexpected CRD installed" problem you're concerned with.

@onedr0p
I really think the .Values.crds.enabled approach is more elegant (+ it's updatable).

The informal standards you refer to sound and awful lot like cargo culting. None of the charts you referenced would be in my list of "idiomatic" charts to base out of context decisions on.

cilium/cilium does their CRDs on the chart too and think it's pretty neat and well thought out.

truecharts-admin referenced this pull request in truecharts/public May 17, 2024
…rnal-dns to v0.14.2@3fcad62 by renovate (#22163)

This PR contains the following updates:

| Package | Update | Change |
|---|---|---|
|
[registry.k8s.io/external-dns/external-dns](https://togithub.com/kubernetes-sigs/external-dns)
| patch | `v0.14.1` -> `v0.14.2` |

---

> [!WARNING]
> Some dependencies could not be looked up. Check the Dependency
Dashboard for more information.

---

### Release Notes

<details>
<summary>kubernetes-sigs/external-dns
(registry.k8s.io/external-dns/external-dns)</summary>

###
[`v0.14.2`](https://togithub.com/kubernetes-sigs/external-dns/releases/tag/v0.14.2)

[Compare
Source](https://togithub.com/kubernetes-sigs/external-dns/compare/v0.14.1...v0.14.2)

#### What's Changed

- kustomize-v0.14.1 by [@&#8203;Raffo](https://togithub.com/Raffo) in
[https://github.com/kubernetes-sigs/external-dns/pull/4331](https://togithub.com/kubernetes-sigs/external-dns/pull/4331)
- replace all links in tutorials for v0.14.1 by
[@&#8203;Raffo](https://togithub.com/Raffo) in
[https://github.com/kubernetes-sigs/external-dns/pull/4332](https://togithub.com/kubernetes-sigs/external-dns/pull/4332)
- chore: upgrade ExternalDNS to go 1.22 by
[@&#8203;mloiseleur](https://togithub.com/mloiseleur) in
[https://github.com/kubernetes-sigs/external-dns/pull/4318](https://togithub.com/kubernetes-sigs/external-dns/pull/4318)
- build(deps): bump the dev-dependencies group with 13 updates by
[@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4329](https://togithub.com/kubernetes-sigs/external-dns/pull/4329)
- build(deps): bump the dev-dependencies group with 5 updates by
[@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4334](https://togithub.com/kubernetes-sigs/external-dns/pull/4334)
- build(deps): bump the dev-dependencies group with 9 updates by
[@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4349](https://togithub.com/kubernetes-sigs/external-dns/pull/4349)
- build(deps): bump the dev-dependencies group with 1 update by
[@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4341](https://togithub.com/kubernetes-sigs/external-dns/pull/4341)
- Add `dnsendpoint` CRD to Helm chart by
[@&#8203;onedr0p](https://togithub.com/onedr0p) in
[https://github.com/kubernetes-sigs/external-dns/pull/4322](https://togithub.com/kubernetes-sigs/external-dns/pull/4322)
- build(deps): bump the dev-dependencies group with 13 updates by
[@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4361](https://togithub.com/kubernetes-sigs/external-dns/pull/4361)
- build(deps): bump GrantBirki/json-yaml-validate from 2.6.1 to 2.6.2 in
the dev-dependencies group by
[@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4364](https://togithub.com/kubernetes-sigs/external-dns/pull/4364)
- chore(chart): Released chart for v0.14.1 by
[@&#8203;stevehipwell](https://togithub.com/stevehipwell) in
[https://github.com/kubernetes-sigs/external-dns/pull/4357](https://togithub.com/kubernetes-sigs/external-dns/pull/4357)
- chore: alphabetical order on providers by
[@&#8203;mloiseleur](https://togithub.com/mloiseleur) in
[https://github.com/kubernetes-sigs/external-dns/pull/4350](https://togithub.com/kubernetes-sigs/external-dns/pull/4350)
- doc: advertise current plan on providers by
[@&#8203;mloiseleur](https://togithub.com/mloiseleur) in
[https://github.com/kubernetes-sigs/external-dns/pull/4365](https://togithub.com/kubernetes-sigs/external-dns/pull/4365)
- Fix(ipv6): support ipv6 shortener and expander equal by
[@&#8203;dongjiang1989](https://togithub.com/dongjiang1989) in
[https://github.com/kubernetes-sigs/external-dns/pull/4351](https://togithub.com/kubernetes-sigs/external-dns/pull/4351)
- feat(WebhookProvider): Let WebhookProvider return `SoftError` on
response status codes >= 500 by
[@&#8203;SimonKienzler](https://togithub.com/SimonKienzler) in
[https://github.com/kubernetes-sigs/external-dns/pull/4319](https://togithub.com/kubernetes-sigs/external-dns/pull/4319)
- Webhook provider: Use correct error gauge in `AdjustEndpoints()` func
by [@&#8203;SimonKienzler](https://togithub.com/SimonKienzler) in
[https://github.com/kubernetes-sigs/external-dns/pull/4374](https://togithub.com/kubernetes-sigs/external-dns/pull/4374)
- build(deps): bump the dev-dependencies group with 18 updates by
[@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4381](https://togithub.com/kubernetes-sigs/external-dns/pull/4381)
- Add exclude domains value in Chart by
[@&#8203;bford-evs](https://togithub.com/bford-evs) in
[https://github.com/kubernetes-sigs/external-dns/pull/4380](https://togithub.com/kubernetes-sigs/external-dns/pull/4380)
- docs(aws): fix typo and upgrade cleanup flow by
[@&#8203;franzudev](https://togithub.com/franzudev) in
[https://github.com/kubernetes-sigs/external-dns/pull/4389](https://togithub.com/kubernetes-sigs/external-dns/pull/4389)
- docs(gke): detail how to configure workload identity by
[@&#8203;userbradley](https://togithub.com/userbradley) in
[https://github.com/kubernetes-sigs/external-dns/pull/4373](https://togithub.com/kubernetes-sigs/external-dns/pull/4373)
- chore(ci): fix failing test by
[@&#8203;mloiseleur](https://togithub.com/mloiseleur) in
[https://github.com/kubernetes-sigs/external-dns/pull/4397](https://togithub.com/kubernetes-sigs/external-dns/pull/4397)
- chore: Update controller-tools version to v0.14.0 by
[@&#8203;dongjiang1989](https://togithub.com/dongjiang1989) in
[https://github.com/kubernetes-sigs/external-dns/pull/4400](https://togithub.com/kubernetes-sigs/external-dns/pull/4400)
- chore(ci): update golangci-lint to v1.57.2 by
[@&#8203;dongjiang1989](https://togithub.com/dongjiang1989) in
[https://github.com/kubernetes-sigs/external-dns/pull/4406](https://togithub.com/kubernetes-sigs/external-dns/pull/4406)
- chore: upgrade ExternalDNS to go 1.22.2 by
[@&#8203;mloiseleur](https://togithub.com/mloiseleur) in
[https://github.com/kubernetes-sigs/external-dns/pull/4414](https://togithub.com/kubernetes-sigs/external-dns/pull/4414)
- build(deps): bump the dev-dependencies group across 1 directory with 4
updates by [@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4412](https://togithub.com/kubernetes-sigs/external-dns/pull/4412)
- build(deps): bump the dev-dependencies group across 1 directory with
24 updates by [@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4416](https://togithub.com/kubernetes-sigs/external-dns/pull/4416)
- custom Azure Active Directory Authority Host by
[@&#8203;Jeremy-Boyle](https://togithub.com/Jeremy-Boyle) in
[https://github.com/kubernetes-sigs/external-dns/pull/4210](https://togithub.com/kubernetes-sigs/external-dns/pull/4210)
- feat(DNSimple): User API tokens by
[@&#8203;IntegralProgrammer](https://togithub.com/IntegralProgrammer) in
[https://github.com/kubernetes-sigs/external-dns/pull/4274](https://togithub.com/kubernetes-sigs/external-dns/pull/4274)
- docs: annotation placement for azuredns tutorial by
[@&#8203;jonas-budde](https://togithub.com/jonas-budde) in
[https://github.com/kubernetes-sigs/external-dns/pull/4415](https://togithub.com/kubernetes-sigs/external-dns/pull/4415)
- feat(azure): add zone name filter for Azure Private DNS by
[@&#8203;khuedoan](https://togithub.com/khuedoan) in
[https://github.com/kubernetes-sigs/external-dns/pull/4346](https://togithub.com/kubernetes-sigs/external-dns/pull/4346)
- test: detect no change necessary with provider specific config by
[@&#8203;szuecs](https://togithub.com/szuecs) in
[https://github.com/kubernetes-sigs/external-dns/pull/4189](https://togithub.com/kubernetes-sigs/external-dns/pull/4189)
- docs: add setup example with helm chart on some providers by
[@&#8203;omerap12](https://togithub.com/omerap12) in
[https://github.com/kubernetes-sigs/external-dns/pull/4405](https://togithub.com/kubernetes-sigs/external-dns/pull/4405)
- test: controller run() and successfully shutdown by
[@&#8203;szuecs](https://togithub.com/szuecs) in
[https://github.com/kubernetes-sigs/external-dns/pull/3639](https://togithub.com/kubernetes-sigs/external-dns/pull/3639)
- fix syntax on cloudflare externalDNS by
[@&#8203;ilyesAj](https://togithub.com/ilyesAj) in
[https://github.com/kubernetes-sigs/external-dns/pull/4436](https://togithub.com/kubernetes-sigs/external-dns/pull/4436)
- build(deps): bump the dev-dependencies group across 1 directory with
11 updates by [@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4440](https://togithub.com/kubernetes-sigs/external-dns/pull/4440)
- chore(chart): Adding extra containers by
[@&#8203;omerap12](https://togithub.com/omerap12) in
[https://github.com/kubernetes-sigs/external-dns/pull/4432](https://togithub.com/kubernetes-sigs/external-dns/pull/4432)
- aws: add ca-west-1 region by
[@&#8203;jeremy-albuixech](https://togithub.com/jeremy-albuixech) in
[https://github.com/kubernetes-sigs/external-dns/pull/4444](https://togithub.com/kubernetes-sigs/external-dns/pull/4444)
- fix: duplicated endpoint per hosted zone by
[@&#8203;leonardocaylent](https://togithub.com/leonardocaylent) in
[https://github.com/kubernetes-sigs/external-dns/pull/4296](https://togithub.com/kubernetes-sigs/external-dns/pull/4296)
- build(deps): bump actions/checkout from 4.1.4 to 4.1.5 in the
dev-dependencies group by
[@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4438](https://togithub.com/kubernetes-sigs/external-dns/pull/4438)
- Add IPv6 AAAA record support to PiHole provider by
[@&#8203;PseudoResonance](https://togithub.com/PseudoResonance) in
[https://github.com/kubernetes-sigs/external-dns/pull/4324](https://togithub.com/kubernetes-sigs/external-dns/pull/4324)
- fix: soft error on cloudflare rate limits by
[@&#8203;ebachle](https://togithub.com/ebachle) in
[https://github.com/kubernetes-sigs/external-dns/pull/4437](https://togithub.com/kubernetes-sigs/external-dns/pull/4437)
- Update cloudflare.md by
[@&#8203;mfreeman451](https://togithub.com/mfreeman451) in
[https://github.com/kubernetes-sigs/external-dns/pull/4449](https://togithub.com/kubernetes-sigs/external-dns/pull/4449)
- Fix headings, whitespace by
[@&#8203;stefanlasiewski](https://togithub.com/stefanlasiewski) in
[https://github.com/kubernetes-sigs/external-dns/pull/4457](https://togithub.com/kubernetes-sigs/external-dns/pull/4457)
- docs: add reference to anexia webhook provider by
[@&#8203;ProbstenHias](https://togithub.com/ProbstenHias) in
[https://github.com/kubernetes-sigs/external-dns/pull/4441](https://togithub.com/kubernetes-sigs/external-dns/pull/4441)
- fix logline mentioning plugin api by
[@&#8203;Raffo](https://togithub.com/Raffo) in
[https://github.com/kubernetes-sigs/external-dns/pull/4459](https://togithub.com/kubernetes-sigs/external-dns/pull/4459)
- docs: lint gke docs + make terraform config more secure by
[@&#8203;DrFaust92](https://togithub.com/DrFaust92) in
[https://github.com/kubernetes-sigs/external-dns/pull/4456](https://togithub.com/kubernetes-sigs/external-dns/pull/4456)
- build(deps): bump action-stars/install-tool-from-github-release from
0.2.2 to 0.2.3 in the dev-dependencies group by
[@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4464](https://togithub.com/kubernetes-sigs/external-dns/pull/4464)
- changed documentation to include more details description when using
API Tokens by [@&#8203;rhjensen79](https://togithub.com/rhjensen79) in
[https://github.com/kubernetes-sigs/external-dns/pull/4474](https://togithub.com/kubernetes-sigs/external-dns/pull/4474)
- fix: add clarification to endpoint unit tests by
[@&#8203;leonardocaylent](https://togithub.com/leonardocaylent) in
[https://github.com/kubernetes-sigs/external-dns/pull/4462](https://togithub.com/kubernetes-sigs/external-dns/pull/4462)
- build(deps): bump the dev-dependencies group across 1 directory with
19 updates by [@&#8203;mloiseleur](https://togithub.com/mloiseleur) in
[https://github.com/kubernetes-sigs/external-dns/pull/4476](https://togithub.com/kubernetes-sigs/external-dns/pull/4476)
- build(deps): bump the dev-dependencies group across 1 directory with
19 updates by [@&#8203;dependabot](https://togithub.com/dependabot) in
[https://github.com/kubernetes-sigs/external-dns/pull/4475](https://togithub.com/kubernetes-sigs/external-dns/pull/4475)

#### New Contributors

- [@&#8203;onedr0p](https://togithub.com/onedr0p) made their first
contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4322](https://togithub.com/kubernetes-sigs/external-dns/pull/4322)
- [@&#8203;SimonKienzler](https://togithub.com/SimonKienzler) made their
first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4319](https://togithub.com/kubernetes-sigs/external-dns/pull/4319)
- [@&#8203;bford-evs](https://togithub.com/bford-evs) made their first
contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4380](https://togithub.com/kubernetes-sigs/external-dns/pull/4380)
- [@&#8203;franzudev](https://togithub.com/franzudev) made their first
contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4389](https://togithub.com/kubernetes-sigs/external-dns/pull/4389)
- [@&#8203;userbradley](https://togithub.com/userbradley) made their
first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4373](https://togithub.com/kubernetes-sigs/external-dns/pull/4373)
- [@&#8203;Jeremy-Boyle](https://togithub.com/Jeremy-Boyle) made their
first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4210](https://togithub.com/kubernetes-sigs/external-dns/pull/4210)
- [@&#8203;IntegralProgrammer](https://togithub.com/IntegralProgrammer)
made their first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4274](https://togithub.com/kubernetes-sigs/external-dns/pull/4274)
- [@&#8203;jonas-budde](https://togithub.com/jonas-budde) made their
first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4415](https://togithub.com/kubernetes-sigs/external-dns/pull/4415)
- [@&#8203;khuedoan](https://togithub.com/khuedoan) made their first
contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4346](https://togithub.com/kubernetes-sigs/external-dns/pull/4346)
- [@&#8203;omerap12](https://togithub.com/omerap12) made their first
contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4405](https://togithub.com/kubernetes-sigs/external-dns/pull/4405)
- [@&#8203;ilyesAj](https://togithub.com/ilyesAj) made their first
contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4436](https://togithub.com/kubernetes-sigs/external-dns/pull/4436)
- [@&#8203;jeremy-albuixech](https://togithub.com/jeremy-albuixech) made
their first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4444](https://togithub.com/kubernetes-sigs/external-dns/pull/4444)
- [@&#8203;leonardocaylent](https://togithub.com/leonardocaylent) made
their first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4296](https://togithub.com/kubernetes-sigs/external-dns/pull/4296)
- [@&#8203;PseudoResonance](https://togithub.com/PseudoResonance) made
their first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4324](https://togithub.com/kubernetes-sigs/external-dns/pull/4324)
- [@&#8203;ebachle](https://togithub.com/ebachle) made their first
contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4437](https://togithub.com/kubernetes-sigs/external-dns/pull/4437)
- [@&#8203;mfreeman451](https://togithub.com/mfreeman451) made their
first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4449](https://togithub.com/kubernetes-sigs/external-dns/pull/4449)
- [@&#8203;ProbstenHias](https://togithub.com/ProbstenHias) made their
first contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4441](https://togithub.com/kubernetes-sigs/external-dns/pull/4441)
- [@&#8203;DrFaust92](https://togithub.com/DrFaust92) made their first
contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4456](https://togithub.com/kubernetes-sigs/external-dns/pull/4456)
- [@&#8203;rhjensen79](https://togithub.com/rhjensen79) made their first
contribution in
[https://github.com/kubernetes-sigs/external-dns/pull/4474](https://togithub.com/kubernetes-sigs/external-dns/pull/4474)

**Full Changelog**:
kubernetes-sigs/external-dns@v0.14.1...v0.14.2

</details>

---

### Configuration

📅 **Schedule**: Branch creation - At any time (no schedule defined),
Automerge - At any time (no schedule defined).

🚦 **Automerge**: Enabled.

♻ **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://togithub.com/renovatebot/renovate).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzNy4zNjguMSIsInVwZGF0ZWRJblZlciI6IjM3LjM2OC4xIiwidGFyZ2V0QnJhbmNoIjoibWFzdGVyIiwibGFiZWxzIjpbImF1dG9tZXJnZSIsInVwZGF0ZS9kb2NrZXIvZ2VuZXJhbC9ub24tbWFqb3IiXX0=-->
@andrewjamesbrown
Copy link

@stevehipwell @onedr0p we just updated to a this version of the chart, and we're now seeing a Warning in ArgoCD.
Context - we pull in multiple copies of the helm chart into a parent chart in order to use multiple DNS providers across multiple AWS accounts, cloudflare, google cloud, etc.; which is why we see the CRD being installed multiple times.

It would be great to have a mechanism to only install the CRD once - either a "CRD chart" like others do, or a flag through values to enable/disable installation of this. Note - we've been using this CRD for quite awhile, we've simply included it in our parent chart.

Thanks!

image

@Skaronator
Copy link

You can disabled installing CRD in Helm.

https://argo-cd.readthedocs.io/en/latest/user-guide/helm/#helm-skip-crds

This also Work in kustomize as you can see here https://github.com/Skaronator/homelab/blob/7f43abef873cd5e0913ee2946a54eaddb91b1b19/network/external-dns-public/kustomization.yaml#L14

@onedr0p
Copy link
Contributor Author

onedr0p commented Jun 3, 2024

You can disabled installing CRD in Helm.

That is exactly what I do too, I have a couple external-dns instances deployed doing different things but only one installs / manages the CRDs with Flux.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
approved Indicates a PR has been approved by an approver from all required OWNERS files. cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. lgtm "Looks good to me", indicates that a PR is ready to be merged. ok-to-test Indicates a non-member PR verified by an org member that is safe to test. size/M Denotes a PR that changes 30-99 lines, ignoring generated files. tide/merge-method-squash Denotes a PR that should be squashed by tide when it merges.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Add CRD - DNSEnpoint to the helm chart template
10 participants