Skip to content

fix(helm): resolve RBAC permissions for namespaced gateway sources#5578

Merged
k8s-ci-robot merged 5 commits intokubernetes-sigs:masterfrom
u-kai:fix/helm-namespaced-gateway-rbac
Jul 14, 2025
Merged

fix(helm): resolve RBAC permissions for namespaced gateway sources#5578
k8s-ci-robot merged 5 commits intokubernetes-sigs:masterfrom
u-kai:fix/helm-namespaced-gateway-rbac

Conversation

@u-kai
Copy link
Member

@u-kai u-kai commented Jun 27, 2025

What does it do ?

This PR resolves RBAC permission issues when using Gateway API sources with namespaced: true configuration in the Helm chart.
It implements proper conditional RBAC creation that supports both same-namespace and cross-namespace gateway access scenarios while maintaining backward compatibility.

Motivation

Fixes #5300 - Gateway API sources require ClusterRole permissions when using namespaced: true, but the current implementation creates insufficient Role permissions, causing external-dns to fail with RBAC errors.

Problem: When namespaced: true is set with gateway sources, external-dns needs:

  • Namespace informer access (ClusterRole for namespaces resource)
  • Gateway resource access (varies based on gatewayNamespace configuration)

Root Cause: The namespace informer uses NamespacesFromSelector functionality which requires cluster-wide namespace access, but namespaced: true only creates Role permissions.

Solution

Implements Split RBAC approach with conditional logic:

Scenarios Supported:

  1. namespaced=false + gateway sources → ClusterRole with all permissions
  2. namespaced=true + gateway sources + no gatewayNamespace → Main Role (with gateway permissions) + ClusterRole for namespaces
  3. namespaced=true + gateway sources + gatewayNamespace specified → Main Role + ClusterRole for namespaces + Cross-namespace Gateway Role
  4. namespaced=false/true + no gateway sources → Standard behavior (unchanged)

More

  • Yes, this PR title follows Conventional Commits
  • Yes, I added unit tests
  • Yes, I updated end user documentation accordingly

@k8s-ci-robot k8s-ci-robot added cncf-cla: yes Indicates the PR's author has signed the CNCF CLA. chart labels Jun 27, 2025
@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 Jun 27, 2025
@k8s-ci-robot
Copy link
Contributor

Hi @u-kai. 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.

Details

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-sigs/prow repository.

@k8s-ci-robot k8s-ci-robot added the size/L Denotes a PR that changes 100-499 lines, ignoring generated files. label Jun 27, 2025
Copy link
Member

@ivankatliarchuk ivankatliarchuk left a comment

Choose a reason for hiding this comment

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

Not sure if this is the correct solution. Why gateway have a distinct flag, when rest of the sources rely on --namespace ? Is there is a specific reason or a mistake?

- --namespace={{ .Release.Namespace }}
{{- end }}
{{- if .Values.gatewayNamespace }}
- --gateway-namespace={{ .Values.gatewayNamespace }}
Copy link
Member

Choose a reason for hiding this comment

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

I think one of the issues is, that Gateway actually uses --gateway-namespace when it should be unified and --namespace is just enough. This is just a confusion.

@u-kai
Copy link
Member Author

u-kai commented Jun 27, 2025

@ivankatliarchuk
Thanks for the feedback!

The separate --gateway-namespace flag aligns with Gateway API's design for cross-namespace routing, where Gateways (often managed by cluster operators) and Routes (managed by app teams) typically reside in different namespaces.

The flag already exists in the external-dns, so this change maintains consistency with the existing CLI interface while fixing the RBAC permissions for namespaced deployments.

@ivankatliarchuk
Copy link
Member

ivankatliarchuk commented Jun 28, 2025

/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 Jun 28, 2025
@ivankatliarchuk
Copy link
Member

I found an initial PR #2292

As short term it seems like a fix. But not clear

Long term solutions are

In my opinion, if --namespace is set, only resouces in this exact namespace should be watched. If there are cross-namespace resource references (it should be ignored with a message that the resource is outside of current namespace scope), it should be either all namespaces or we need to add multiple namespace support.

@ivankatliarchuk
Copy link
Member

Related issues:

@k8s-ci-robot k8s-ci-robot added size/XL Denotes a PR that changes 500-999 lines, ignoring generated files. and removed size/L Denotes a PR that changes 100-499 lines, ignoring generated files. labels Jun 29, 2025
@k8s-ci-robot k8s-ci-robot added size/L Denotes a PR that changes 100-499 lines, ignoring generated files. and removed size/XL Denotes a PR that changes 500-999 lines, ignoring generated files. labels Jun 29, 2025
@u-kai
Copy link
Member Author

u-kai commented Jun 29, 2025

@ivankatliarchuk
I agree that supporting multiple namespaces with the --namespace option would be a valuable improvement in the long term.

That said, I’d like to clarify one point — does this proposal also imply deprecating or integrating the --gateway-namespace option?

If so, my personal opinion is that --gateway-namespace still has value and should remain.
When supporting multiple namespaces, we’ll likely need to create one informer per namespace. Without a --gateway-namespace option, we wouldn't know which namespace the Gateway actually exists in, which could result in unnecessary informer overhead, especially when the Gateway is deployed in a single, shared namespace (as is often the case in common Gateway setups).

In such cases, having a dedicated --gateway-namespace provides a useful optimization and avoids wasteful resource watching.

So in conclusion, I’m in favor of enabling multi-namespace support for --namespace, but I think retaining --gateway-namespace is also beneficial from a performance and configuration clarity standpoint.

@ivankatliarchuk
Copy link
Member

@mloiseleur wdyt?

@mloiseleur
Copy link
Collaborator

In External DNS doc on flags, it says:

  • --namespace: Limit resources queried for endpoints to a specific namespace (default: all namespaces)
  • --gateway-namespace: Limit Gateways of Route endpoints to a specific namespace (default: all namespaces)

With current state of External DNS, this PR looks valid to me. It allows user to use the same namespace or different namespace, with similar names between the binary and the chart. For instance, a user may want to use external dns CRD on external-dns namespace and Gateway on gateway namespaces.

@ivankatliarchuk An answer to your idea would be to implement a --namespaces options, allowing to set multiple namespaces. Then it would make sense to remove specific namespace options tailored for a specific source. But that's clearly beyond the scope of this PR.

Copy link
Collaborator

@mloiseleur mloiseleur left a comment

Choose a reason for hiding this comment

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

@u-kai About the implementation, why are you adding a specific ClusterRole and ClusterRoleBinding ? Wouldn't it be simpler to use the same CR & CRB with just extended required permissions ?

@ivankatliarchuk
Copy link
Member

Make sense

@u-kai
Copy link
Member Author

u-kai commented Jul 4, 2025

@mloiseleur
Thank you for the feedback!

Let me explain the implementation. For namespaced: true configurations, multiple Role/ClusterRole resources are necessary for the following reasons:

Technical Requirements:

  1. Base Permissions - When namespaced: true, typically a Role (not ClusterRole) is created for namespace-scoped permissions
  2. Namespace Informer - When using Gateway API sources like HTTPRoute, cluster-wide namespace read access is required for the NamespacesFromSelector functionality
  3. Principle of Least Privilege - We should only grant permissions when actually needed:
  • namespaced: true → base permissions via Role
  • Gateway API sources → additional ClusterRole for namespace access only when used
  1. Cross-namespace Gateway - In practice, Gateways often exist in different namespaces than Routes (e.g., infrastructure namespace vs application namespace). When users desire this setup (e.g., gatewayNamespace: default), a separate Role is needed for cross-namespace access

Implementation Approach:

  • Base permissions: Role (when namespaced)
  • Namespace access: ClusterRole (only when Gateway sources are used)
  • Cross-namespace Gateway: Role in target namespace (only when specified)

This design grants exactly the permissions needed for each scenario while maintaining security isolation.

@mloiseleur
Copy link
Collaborator

/assign @stevehipwell
for review

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 @u-kai. I've added a comment suggesting an improvement but as I'd like to include this in the next release we can leave that for the next time we need to make changes.

/approve

Check if any Gateway API sources are enabled
*/}}
{{- define "external-dns.hasGatewaySources" -}}
{{- if or (has "gateway-httproute" .Values.sources) (has "gateway-grpcroute" .Values.sources) (has "gateway-tlsroute" .Values.sources) (has "gateway-tcproute" .Values.sources) (has "gateway-udproute" .Values.sources) -}}
Copy link
Contributor

Choose a reason for hiding this comment

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

Why not use hasPrefix in a range loop so the code is less likely to need updating in the future?

@k8s-ci-robot k8s-ci-robot added the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Jul 14, 2025
@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

Details 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 Jul 14, 2025
@stevehipwell
Copy link
Contributor

@mloiseleur @ivankatliarchuk could one of you please add the LGTM if you're happy with this?

Copy link
Member

@ivankatliarchuk ivankatliarchuk left a comment

Choose a reason for hiding this comment

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

/lgtm

@k8s-ci-robot k8s-ci-robot merged commit a270a32 into kubernetes-sigs:master Jul 14, 2025
15 checks passed
troll-os pushed a commit to FiligranHQ/external-dns that referenced this pull request Aug 28, 2025
…ubernetes-sigs#5578)

* fix(helm): resolve RBAC permissions for namespaced gateway sources

* feat(helm): add support for gateway namespace in RBAC configuration

* chore(helm): update docs and fix formatting issues

* fix(helm): revert README changes and add gatewayNamespace docs

* chore lint fmt
JesusMtnez pushed a commit to JesusMtnez/homelab that referenced this pull request Dec 1, 2025
…o v0.19.0 (#805)

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.18.0` -> `v0.19.0` |

---

### Release Notes

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

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

[Compare Source](kubernetes-sigs/external-dns@v0.18.0...v0.19.0)

#### General information

- :information\_source: CLI flags allows to set behavior of previous version on the two breaking changes included in this release, if needed.
- :information\_source: Thanks to [@&#8203;valerian-roche](https://github.com/valerian-roche), this version can reduce the *average* memory usage by \~10 times, see [#&#8203;5596](kubernetes-sigs/external-dns#5596)

#### ⚠️ Breaking Changes

- feat(nodes)!: expose external ipv6 by default by [@&#8203;mloiseleur](https://github.com/mloiseleur) in [#&#8203;5575](kubernetes-sigs/external-dns#5575)
- feat(traefik)!: disable legacy listeners on traefik.containo.us API Group by [@&#8203;mloiseleur](https://github.com/mloiseleur) in [#&#8203;5565](kubernetes-sigs/external-dns#5565)

#### 🚀 Features

- feat(aws): add support for ap-east-2 by [@&#8203;chemi0213](https://github.com/chemi0213) in [#&#8203;5638](kubernetes-sigs/external-dns#5638)
- feat(aws): add support for geoproximity routing by [@&#8203;prasadkatti](https://github.com/prasadkatti) in [#&#8203;5347](kubernetes-sigs/external-dns#5347)
- feat(azure): update Azure provider configuration and documentation by [@&#8203;antchand](https://github.com/antchand) in [#&#8203;5648](kubernetes-sigs/external-dns#5648)
- feat(chart): add option to configure annotationFilter via dedicated helm value by [@&#8203;dshatokhin](https://github.com/dshatokhin) in [#&#8203;5737](kubernetes-sigs/external-dns#5737)
- feat(events): raise k8s events with fake provider by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5659](kubernetes-sigs/external-dns#5659)
- feat(metrics): publish build\_info metric by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5643](kubernetes-sigs/external-dns#5643)
- feat(nodes)!: expose external ipv6 by default by [@&#8203;mloiseleur](https://github.com/mloiseleur) in [#&#8203;5575](kubernetes-sigs/external-dns#5575)
- feat(source/istio): support version 1.25+ by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5611](kubernetes-sigs/external-dns#5611)
- feat(source/pods): support for annotation and label filter by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5583](kubernetes-sigs/external-dns#5583)
- feat(source): support --event flags with sources pod and node by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5642](kubernetes-sigs/external-dns#5642)
- feat(source): use transformers in pod informers to reduce memory footprint by [@&#8203;valerian-roche](https://github.com/valerian-roche) in [#&#8203;5596](kubernetes-sigs/external-dns#5596)
- feat(traefik)!: disable legacy listeners on traefik.containo.us API Group by [@&#8203;mloiseleur](https://github.com/mloiseleur) in [#&#8203;5565](kubernetes-sigs/external-dns#5565)

#### 🐛 Bug fixes

- fix(api): rollback oas and update linter by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5723](kubernetes-sigs/external-dns#5723)
- fix(aws): support aws\_ca\_bundle by [@&#8203;mwmix](https://github.com/mwmix) in [#&#8203;5665](kubernetes-sigs/external-dns#5665)
- fix(chart): Change .extraContainers type to array by [@&#8203;svengreb](https://github.com/svengreb) in [#&#8203;5564](kubernetes-sigs/external-dns#5564)
- fix(cloudflare): display of action in logs by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5550](kubernetes-sigs/external-dns#5550)
- fix(cloudflare): set comments properly by [@&#8203;7onn](https://github.com/7onn) in [#&#8203;5582](kubernetes-sigs/external-dns#5582)
- fix(cloudflare): unnecessary record updates by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5770](kubernetes-sigs/external-dns#5770)
- fix(controller): panic in events.Controller.Add() by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5766](kubernetes-sigs/external-dns#5766)
- fix(docs): Fixing some errors in the dev-guide example. by [@&#8203;mwmix](https://github.com/mwmix) in [#&#8203;5662](kubernetes-sigs/external-dns#5662)
- fix(endpoint): domains handling with idna by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5685](kubernetes-sigs/external-dns#5685)
- fix(helm): resolve RBAC permissions for namespaced gateway sources by [@&#8203;u-kai](https://github.com/u-kai) in [#&#8203;5578](kubernetes-sigs/external-dns#5578)
- fix(helm): Update helm value schema to allow `create-only` policy type by [@&#8203;coltonhughes](https://github.com/coltonhughes) in [#&#8203;5627](kubernetes-sigs/external-dns#5627)
- fix(http): concurrent map read/write by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5753](kubernetes-sigs/external-dns#5753)
- fix(instrumented\_http): migrate to own http instrumenter by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5650](kubernetes-sigs/external-dns#5650)
- fix(metrics): make prometheus labels more type safe by [@&#8203;mwmix](https://github.com/mwmix) in [#&#8203;5717](kubernetes-sigs/external-dns#5717)
- fix(oas): add required properties to api components by [@&#8203;evilhamsterman](https://github.com/evilhamsterman) in [#&#8203;5696](kubernetes-sigs/external-dns#5696)
- fix(pihole): create record for all targets by [@&#8203;vkolobara](https://github.com/vkolobara) in [#&#8203;5584](kubernetes-sigs/external-dns#5584)
- fix(provider/aws): null pointer when records mailformed by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5639](kubernetes-sigs/external-dns#5639)
- fix(provider/aws-sd): fix namespace type filtering by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5682](kubernetes-sigs/external-dns#5682)
- fix(provider): IDNA awareness in the zone finder by [@&#8203;hanapedia](https://github.com/hanapedia) in [#&#8203;5705](kubernetes-sigs/external-dns#5705)
- fix(rbac): conditional endpointslices perms by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5746](kubernetes-sigs/external-dns#5746)
- fix: reduce warning by using idna profile by [@&#8203;szuecs](https://github.com/szuecs) in [#&#8203;5587](kubernetes-sigs/external-dns#5587)
- fix(rfc2136): Use correct index for accessing UpdateOld if there are multiple chunks by [@&#8203;schwajo](https://github.com/schwajo) in [#&#8203;5542](kubernetes-sigs/external-dns#5542)
- fix(source): respect --expose-internal-ipv6 flag on NodePort services by [@&#8203;jonasbadstuebner](https://github.com/jonasbadstuebner) in [#&#8203;5652](kubernetes-sigs/external-dns#5652)
- fix(source/service): disable node informer when not required by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5613](kubernetes-sigs/external-dns#5613)
- fix(source/service): disable pod and endpointSlices informers when they are not needed by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5646](kubernetes-sigs/external-dns#5646)
- fix(source/service): make sure only unique targets available for futher processing by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5614](kubernetes-sigs/external-dns#5614)
- fix(txt-registry): skip creation of already-existing TXT records ([#&#8203;4914](kubernetes-sigs/external-dns#4914)) by [@&#8203;u-kai](https://github.com/u-kai) in [#&#8203;5459](kubernetes-sigs/external-dns#5459)
- fix: zonefinder used wrong quotation style by [@&#8203;szuecs](https://github.com/szuecs) in [#&#8203;5588](kubernetes-sigs/external-dns#5588)

#### 📝 Documentation

- docs: add information on external webhook usage by [@&#8203;Raffo](https://github.com/Raffo) in [#&#8203;5606](kubernetes-sigs/external-dns#5606)
- docs: add new webhook provider SAKURA Cloud into README by [@&#8203;ippanpeople](https://github.com/ippanpeople) in [#&#8203;5784](kubernetes-sigs/external-dns#5784)
- docs(aws): add helm repo command to the tutorial by [@&#8203;raghu-manne](https://github.com/raghu-manne) in [#&#8203;5618](kubernetes-sigs/external-dns#5618)
- docs: fix typo in compatibility table by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5769](kubernetes-sigs/external-dns#5769)
- docs(istio): document ingress annotation by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5756](kubernetes-sigs/external-dns#5756)
- docs(providers): add Myra Security DNS to the list by [@&#8203;armaaar](https://github.com/armaaar) in [#&#8203;5671](kubernetes-sigs/external-dns#5671)
- docs(readme): update k8s compatiblity table by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5747](kubernetes-sigs/external-dns#5747)
- docs: remove substitution in AES keygen examples by [@&#8203;super-octo-spoon](https://github.com/super-octo-spoon) in [#&#8203;5686](kubernetes-sigs/external-dns#5686)
- docs(source/service): headless records and root/base domain by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5624](kubernetes-sigs/external-dns#5624)

#### 📦 Others

- chore(ci): improve releaser script by [@&#8203;mloiseleur](https://github.com/mloiseleur) in [#&#8203;5571](kubernetes-sigs/external-dns#5571)
- chore(ci): update labels automation by [@&#8203;mloiseleur](https://github.com/mloiseleur) in [#&#8203;5580](kubernetes-sigs/external-dns#5580)
- chore(cloudflare): migrate CreateDNSRecord() to new lib by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5779](kubernetes-sigs/external-dns#5779)
- chore(cloudflare): migrate DNSRecord to new lib struct by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5762](kubernetes-sigs/external-dns#5762)
- chore(cloudflare): rename zoneService fields by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5761](kubernetes-sigs/external-dns#5761)
- chore(cloudflare): upgrade library to v5 by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5734](kubernetes-sigs/external-dns#5734)
- chore(cloudflare): use lib v4 for regional services by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5609](kubernetes-sigs/external-dns#5609)
- chore(codebase): code reuse by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5607](kubernetes-sigs/external-dns#5607)
- chore(codebase): enable linter nonamedreturns by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5594](kubernetes-sigs/external-dns#5594)
- chore(codebase): remove pointer to an interface by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5625](kubernetes-sigs/external-dns#5625)
- chore(deps): bump github.com/cloudflare/cloudflare-go/v4 from 4.5.1 to 4.6.0 in the dev-dependencies group by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5645](kubernetes-sigs/external-dns#5645)
- chore(deps): bump github.com/digitalocean/godo from 1.155.0 to 1.156.0 in the dev-dependencies group by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5623](kubernetes-sigs/external-dns#5623)
- chore(deps): bump github.com/oracle/oci-go-sdk/v65 from 65.94.0 to 65.95.0 in the dev-dependencies group by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5597](kubernetes-sigs/external-dns#5597)
- chore(deps): bump google.golang.org/api from 0.239.0 to 0.240.0 in the dev-dependencies group by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5605](kubernetes-sigs/external-dns#5605)
- chore(deps): bump renovatebot/github-action from 43.0.1 to 43.0.2 in the dev-dependencies group by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5592](kubernetes-sigs/external-dns#5592)
- chore(deps): bump renovatebot/github-action from 43.0.2 to 43.0.3 in the dev-dependencies group by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5644](kubernetes-sigs/external-dns#5644)
- chore(deps): bump renovatebot/github-action from 43.0.4 to 43.0.5 in the dev-dependencies group by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5691](kubernetes-sigs/external-dns#5691)
- chore(deps): bump the dev-dependencies group across 1 directory with 10 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5760](kubernetes-sigs/external-dns#5760)
- chore(deps): bump the dev-dependencies group across 1 directory with 17 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5704](kubernetes-sigs/external-dns#5704)
- chore(deps): bump the dev-dependencies group across 1 directory with 17 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5726](kubernetes-sigs/external-dns#5726)
- chore(deps): bump the dev-dependencies group across 1 directory with 18 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5739](kubernetes-sigs/external-dns#5739)
- chore(deps): bump the dev-dependencies group across 1 directory with 2 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5667](kubernetes-sigs/external-dns#5667)
- chore(deps): bump the dev-dependencies group across 1 directory with 2 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5732](kubernetes-sigs/external-dns#5732)
- chore(deps): bump the dev-dependencies group across 1 directory with 2 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5759](kubernetes-sigs/external-dns#5759)
- chore(deps): bump the dev-dependencies group across 1 directory with 3 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5579](kubernetes-sigs/external-dns#5579)
- chore(deps): bump the dev-dependencies group across 1 directory with 5 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5690](kubernetes-sigs/external-dns#5690)
- chore(deps): bump the dev-dependencies group across 1 directory with 8 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5637](kubernetes-sigs/external-dns#5637)
- chore(deps): bump the dev-dependencies group across 1 directory with 8 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5658](kubernetes-sigs/external-dns#5658)
- chore(deps): bump the dev-dependencies group with 10 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5668](kubernetes-sigs/external-dns#5668)
- chore(deps): bump the dev-dependencies group with 2 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5610](kubernetes-sigs/external-dns#5610)
- chore(deps): bump the dev-dependencies group with 3 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5628](kubernetes-sigs/external-dns#5628)
- chore(deps): bump the dev-dependencies group with 4 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5593](kubernetes-sigs/external-dns#5593)
- chore(deps): bump the dev-dependencies group with 4 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5673](kubernetes-sigs/external-dns#5673)
- chore(deps): bump the dev-dependencies group with 9 updates by [@&#8203;app/dependabot](https://github.com/app/dependabot) in [#&#8203;5763](kubernetes-sigs/external-dns#5763)
- chore(deps): update golangci-lint version to v2.2.2 by [@&#8203;dongjiang1989](https://github.com/dongjiang1989) in [#&#8203;5670](kubernetes-sigs/external-dns#5670)
- chore(endpoint): fix typo by [@&#8203;bachorp](https://github.com/bachorp) in [#&#8203;5787](kubernetes-sigs/external-dns#5787)
- chore(github-actions): test execution with low resources by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5729](kubernetes-sigs/external-dns#5729)
- chore(github): enchance issue-template for bug-report by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5692](kubernetes-sigs/external-dns#5692)
- chore(helm): add rbac unit-tests for istio sources by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5752](kubernetes-sigs/external-dns#5752)
- chore(metrics): refactor metrics to use common registry by [@&#8203;mwmix](https://github.com/mwmix) in [#&#8203;5677](kubernetes-sigs/external-dns#5677)
- chore(plan): added tests for cases with asterisks by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5640](kubernetes-sigs/external-dns#5640)
- chore(provider/aws): reduce if-nesting for dryRun condition by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5688](kubernetes-sigs/external-dns#5688)
- chore: release chart for v0.18.0 by [@&#8203;elafarge](https://github.com/elafarge) in [#&#8203;5633](kubernetes-sigs/external-dns#5633)
- chore(release): updates kustomize & docs with v0.18.0 by [@&#8203;mloiseleur](https://github.com/mloiseleur) in [#&#8203;5573](kubernetes-sigs/external-dns#5573)
- chore(source/istio): replace kube API calls with caching and ingress informers by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5743](kubernetes-sigs/external-dns#5743)
- chore(source/net-filter): improve flow logic and add more tests by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5629](kubernetes-sigs/external-dns#5629)
- chore(source): reorganise sources and wrappers by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5598](kubernetes-sigs/external-dns#5598)
- chore(source): use types instead of strings by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5699](kubernetes-sigs/external-dns#5699)
- chore(store\*): add reduce complexity and improve code coverage by [@&#8203;AndrewCharlesHay](https://github.com/AndrewCharlesHay) in [#&#8203;5568](kubernetes-sigs/external-dns#5568)
- refactor(annotations): use common prefix to simplify filtering in informer transformers by [@&#8203;valerian-roche](https://github.com/valerian-roche) in [#&#8203;5621](kubernetes-sigs/external-dns#5621)
- refactor(cloudflare): use lib v4 for zone services by [@&#8203;AndrewCharlesHay](https://github.com/AndrewCharlesHay) in [#&#8203;5654](kubernetes-sigs/external-dns#5654)
- refactor(provider/cloudflare): use local regionalHostname struct by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5615](kubernetes-sigs/external-dns#5615)
- refactor(source): document and add debug information on wrappers by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5687](kubernetes-sigs/external-dns#5687)
- refactor(source/istio): add transformers by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5728](kubernetes-sigs/external-dns#5728)
- refactor: use slices.Contains instead of handrolled for loop by [@&#8203;szuecs](https://github.com/szuecs) in [#&#8203;5589](kubernetes-sigs/external-dns#5589)
- test: improve coverage on http and metrics by [@&#8203;mwmix](https://github.com/mwmix) in [#&#8203;5712](kubernetes-sigs/external-dns#5712)
- test(source/istio): add missing edge cases with tests by [@&#8203;ivankatliarchuk](https://github.com/ivankatliarchuk) in [#&#8203;5715](kubernetes-sigs/external-dns#5715)
- tests(source/crd): increase timeouts when it can randomly fails by [@&#8203;vflaux](https://github.com/vflaux) in [#&#8203;5785](kubernetes-sigs/external-dns#5785)

#### 📦 Docker Image

```
docker pull registry.k8s.io/external-dns/external-dns:v0.19.0
```

#### New Contributors

- [@&#8203;svengreb](https://github.com/svengreb) made their first contribution in [#&#8203;5564](kubernetes-sigs/external-dns#5564)
- [@&#8203;schwajo](https://github.com/schwajo) made their first contribution in [#&#8203;5542](kubernetes-sigs/external-dns#5542)
- [@&#8203;valerian-roche](https://github.com/valerian-roche) made their first contribution in [#&#8203;5621](kubernetes-sigs/external-dns#5621)
- [@&#8203;chemi0213](https://github.com/chemi0213) made their first contribution in [#&#8203;5638](kubernetes-sigs/external-dns#5638)
- [@&#8203;vkolobara](https://github.com/vkolobara) made their first contribution in [#&#8203;5584](kubernetes-sigs/external-dns#5584)
- [@&#8203;raghu-manne](https://github.com/raghu-manne) made their first contribution in [#&#8203;5618](kubernetes-sigs/external-dns#5618)
- [@&#8203;coltonhughes](https://github.com/coltonhughes) made their first contribution in [#&#8203;5627](kubernetes-sigs/external-dns#5627)
- [@&#8203;elafarge](https://github.com/elafarge) made their first contribution in [#&#8203;5633](kubernetes-sigs/external-dns#5633)
- [@&#8203;mwmix](https://github.com/mwmix) made their first contribution in [#&#8203;5662](kubernetes-sigs/external-dns#5662)
- [@&#8203;super-octo-spoon](https://github.com/super-octo-spoon) made their first contribution in [#&#8203;5686](kubernetes-sigs/external-dns#5686)
- [@&#8203;armaaar](https://github.com/armaaar) made their first contribution in [#&#8203;5671](kubernetes-sigs/external-dns#5671)
- [@&#8203;hanapedia](https://github.com/hanapedia) made their first contribution in [#&#8203;5705](kubernetes-sigs/external-dns#5705)
- [@&#8203;evilhamsterman](https://github.com/evilhamsterman) made their first contribution in [#&#8203;5696](kubernetes-sigs/external-dns#5696)
- [@&#8203;dshatokhin](https://github.com/dshatokhin) made their first contribution in [#&#8203;5737](kubernetes-sigs/external-dns#5737)
- [@&#8203;antchand](https://github.com/antchand) made their first contribution in [#&#8203;5648](kubernetes-sigs/external-dns#5648)
- [@&#8203;ippanpeople](https://github.com/ippanpeople) made their first contribution in [#&#8203;5784](kubernetes-sigs/external-dns#5784)
- [@&#8203;bachorp](https://github.com/bachorp) made their first contribution in [#&#8203;5787](kubernetes-sigs/external-dns#5787)

**Full Changelog**: <kubernetes-sigs/external-dns@v0.18.0...v0.19.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:eyJjcmVhdGVkSW5WZXIiOiI0MS45My4yIiwidXBkYXRlZEluVmVyIjoiNDEuOTMuMiIsInRhcmdldEJyYW5jaCI6Im1haW4iLCJsYWJlbHMiOlsiZGVwL21pbm9yIl19-->

Reviewed-on: https://codeberg.org/JesusMtnez/homelab/pulls/805
Co-authored-by: JesusMtnez-bot <jesusmartinez93+bot@gmail.com>
Co-committed-by: JesusMtnez-bot <jesusmartinez93+bot@gmail.com>
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. chart 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/L Denotes a PR that changes 100-499 lines, ignoring generated files.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

--namespace still trying to read various cluster scope

5 participants