Skip to content

Conversation

@mwmix
Copy link
Contributor

@mwmix mwmix commented Jul 20, 2025

What does it do ?

Fixes an issue when you have the AWS_CA_BUNDLE set and are using the 'aws' provider. The error is as follows:

instantiating AWS config: unable to add custom RootCAs HTTPClient, has no WithTransportOptions, *http.Client

Motivation

This causes me a ton of headache recently and I was forced to use a Debian based container of the tool as opposed to the scratch based one.

More

  • [ x ] Yes, this PR title follows Conventional Commits
  • [ x ] Yes, I added unit tests
  • [ x ] 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. provider Issues or PRs related to a provider labels Jul 20, 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 Jul 20, 2025
@k8s-ci-robot
Copy link
Contributor

Hi @mwmix. 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-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 Jul 20, 2025
Copy link
Member

Choose a reason for hiding this comment

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

Configuring metrics per provider not a great idea. Please avoid that.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I agree with you, I've been struggling to find a better implementation. Any insights would be appreciated.

Copy link
Member

Choose a reason for hiding this comment

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

		config.WithHTTPClient(extdnshttp.NewInstrumentedClient(AWSHTTPCLIENT)),

^ Something simliar

What happens if we simply add WithCustomCABundle, my understanding it could work, even if we wrapping http client

Copy link
Contributor Author

@mwmix mwmix Jul 20, 2025

Choose a reason for hiding this comment

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

I tried to come up with a way to do what you suggested before I dived down the middleware rabbit hole. But, I kept hitting road blocks. The closest I could get was this and we get a type error:

func NewInstrumentedAWSClient(next *awshttp.BuildableClient) *awshttp.BuildableClient) {
    next.WithTransportOptions(func(transport *http.Transport) {
			transport = NewInstrumentedTransport(next)
		})
}

The type error is

cannot use next (variable of type *"github.com/aws/aws-sdk-go-v2/aws/transport/http".BuildableClient) as "net/http".RoundTripper value in argument to NewInstrumentedTransport: *"github.com/aws/aws-sdk-go-v2/aws/transport/http".BuildableClient does not implement "net/http".RoundTripper (missing method RoundTrip) 

So the WithCustomCABundle would "work" and so does just updating my systems trusted ca list. However, the moment we set AWS_CA_BUNDLE even with the WithCustomCABundle set then we still hit that error. One workaround would be to use WithCustomCABundle pulling the value from AWS_CA_BUNDLE and then unsetting the environment variable so the SDK doesn't use it. But, I imagine that has it's own issues ...

When looking at other projects such as otel and based on my own reading of the documentation it seemed like this was the expected interface for adding this sort of functionality.

I'm not really married to any particular solution and appreciate your feedback. I've been trying my best to minimize the impact of the changes while preserving the existing instrumentation but haven't found any cleaner way around it.

Copy link
Member

Choose a reason for hiding this comment

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

I do not have access to AWS. If you could reproduce it with kind+localstack or similar, might be able to have a look.

Have you tried WithCustomCABundle?

Copy link
Member

Choose a reason for hiding this comment

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

As well, have you tried for example

config.WithHTTPClient(extdnshttp.NewInstrumentedClient(&http.Client{Transport: transport.NewBuildableClient().GetTransport()})),

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I tried WithCustomCABundle() and the error still appears when I try to run with the AWS_CA_BUNDLE defined.

I just also finished testing the last example you gave me above with the same result :(

Copy link
Member

Choose a reason for hiding this comment

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

Gotcha

Copy link
Member

@ivankatliarchuk ivankatliarchuk Jul 22, 2025

Choose a reason for hiding this comment

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

Just a note about opentelemetry. It's ok to have a middleware support, but still expected to to support RoundTrippers https://github.com/open-telemetry/opentelemetry-go-contrib/blob/caee80916a50f168c7152967dabaefd0c3cd17c0/instrumentation/net/http/otelhttp/transport.go#L26

Basically to be a consistent across multiple libraries. With aws there is no such option, it's quite aws specific

Copy link
Member

Choose a reason for hiding this comment

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

Can we keep everything within the existing package sigs.k8s.io/external-dns/pkg/http, unless there’s a circular dependency that prevents it or other valid reason?

Please note that packages named utils are not being approved at this time.
For reference, see this example where a similar utils package was proposed but not accepted: #5189 (comment).

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Sure, ty for the insight. I'll update the MR appropriately.

Copy link
Member

Choose a reason for hiding this comment

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

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yeah absolutely, I didn't realize you already had some stashed away in the repo! :)

@mwmix mwmix force-pushed the fix-aws-ca-bundle branch 3 times, most recently from 7b1027a to ae5a1bd Compare July 20, 2025 12:50
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.

There should be a simple reason why certificate bundle is not loaded. Hard to say without how-to-reproduce example

Copy link
Member

Choose a reason for hiding this comment

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

As well, have you tried for example

config.WithHTTPClient(extdnshttp.NewInstrumentedClient(&http.Client{Transport: transport.NewBuildableClient().GetTransport()})),

@ivankatliarchuk
Copy link
Member

The WHY is not working is described here https://github.com/aws/aws-sdk-go-v2/blob/f9f7a6bb124a1a7daffc65db40053d97678bd371/config/env_config.go#L174-L189. In principal, AWS sdk instead of Transport should have RoundTripper, as go http library does.

Could we add to our instrumenter an option to wrap and return Transport if config.WithHTTPClient(extdnshttp.NewInstrumentedClient(&http.Client{Transport: transport.NewBuildableClient().GetTransport()})), not going to work?

Middleware is an OK way, but AWS library middleware is just to complex.

@k8s-ci-robot k8s-ci-robot added the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Jul 21, 2025
@ivankatliarchuk
Copy link
Member

ivankatliarchuk commented Jul 21, 2025

Technically, if we passing a Transport (cfg.HTTPClient.(*awshttp.BuildableClient)) then resolveCustomCABundle https://github.com/aws/aws-sdk-go-v2/blob/f9f7a6bb124a1a7daffc65db40053d97678bd371/config/resolve.go#L42 should attach TLS certs.

Just need to find out how to enhance it with our metrics.

@ivankatliarchuk
Copy link
Member

I'm unsure actually. I do get why AWS team done it that way, but not simple to extend.

/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 Jul 21, 2025
@mwmix mwmix force-pushed the fix-aws-ca-bundle branch from ae5a1bd to 58a3257 Compare July 21, 2025 23:21
@k8s-ci-robot k8s-ci-robot removed the needs-rebase Indicates a PR cannot be merged because it has merge conflicts with HEAD. label Jul 21, 2025
@ivankatliarchuk
Copy link
Member

/retitle fix(aws): support aws_ca_bundle

@k8s-ci-robot k8s-ci-robot changed the title Fix aws ca bundle fix(aws): support aws_ca_bundle Jul 22, 2025
pkg/http/http.go Outdated
Copy link
Member

Choose a reason for hiding this comment

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

Ideally this should stay. The plan is to wrap it like here

RegisterMetric.MustRegister(NewGaugeFuncMetric(prometheus.GaugeOpts{
or here
registryErrorsTotal = metrics.NewCounterWithOpts(
as we have documentation for metrics automated https://github.com/kubernetes-sigs/external-dns/blob/master/docs/monitoring/metrics.md

Copy link
Member

Choose a reason for hiding this comment

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

Changing this, may affect kube monitoring as well, which is not desirable.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I pushed a new commit which refactors the fix to use the common metrics registry. Does that work? Or do we want to split that into a different PR?

Copy link
Member

Choose a reason for hiding this comment

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

If you have time, would be better to slice PRs.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Okay I've modified this PR so it has what I hope is the minimum set of changes you were hoping for. I'll have another PR out either later tonight / tomorrow which will be branched off this with the other changes I made.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Opened PR #5677 for the metrics refactoring.

@mwmix mwmix force-pushed the fix-aws-ca-bundle branch from 58a3257 to d7eb392 Compare July 22, 2025 22:27
@k8s-ci-robot k8s-ci-robot added docs internal Issues or PRs related to internal code metrics Issues or PRs related to metrics labels Jul 22, 2025
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.

The code LGTM.
Like for the previous change on metrics, the latest refactor asked by @ivankatliarchuk should go in its own dedicated PR.

=> Would you please extract the code in pkg/http & pkg/metrics in a dedicated refactor PR ?

@mwmix mwmix force-pushed the fix-aws-ca-bundle branch from 90d10ba to 474d1fc Compare August 5, 2025 22:42
@k8s-ci-robot k8s-ci-robot added size/L Denotes a PR that changes 100-499 lines, ignoring generated files. and removed lgtm "Looks good to me", indicates that a PR is ready to be merged. size/XL Denotes a PR that changes 500-999 lines, ignoring generated files. labels Aug 5, 2025
@mwmix
Copy link
Contributor Author

mwmix commented Aug 5, 2025

The code LGTM. Like for the previous change on metrics, the latest refactor asked by @ivankatliarchuk should go in its own dedicated PR.

=> Would you please extract the code in pkg/http & pkg/metrics in a dedicated refactor PR ?

Yep can do, new PR opened #5717.

@mwmix mwmix force-pushed the fix-aws-ca-bundle branch 2 times, most recently from 5a6a8b3 to 45c8da8 Compare August 6, 2025 01:45
Copy link
Member

Choose a reason for hiding this comment

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

I wonder how this works without issues. The package pkg/http depends on pkg/metrics. Interesting, I would expect cyclic dependency

@mloiseleur
Copy link
Collaborator

/lgtm
@ivankatliarchuk I'll let you proceed with the final review.

@k8s-ci-robot k8s-ci-robot added the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Aug 6, 2025
@ivankatliarchuk
Copy link
Member

It seems like no issues. so lgtm as well

/approve

@k8s-ci-robot k8s-ci-robot added the approved Indicates a PR has been approved by an approver from all required OWNERS files. label Aug 6, 2025
@ivankatliarchuk
Copy link
Member

ivankatliarchuk commented Aug 6, 2025

Fixes #5666

@ivankatliarchuk
Copy link
Member

ivankatliarchuk commented Aug 6, 2025

Screenshot 2025-08-06 at 09 41 33

Looks like on 1CPU machine it will not work, want compile or compile with some flakyness.

@ivankatliarchuk
Copy link
Member

/remove-approve

@k8s-ci-robot k8s-ci-robot removed the approved Indicates a PR has been approved by an approver from all required OWNERS files. label Aug 6, 2025
@mwmix mwmix force-pushed the fix-aws-ca-bundle branch from 45c8da8 to 937be24 Compare August 6, 2025 22:25
@k8s-ci-robot k8s-ci-robot removed the lgtm "Looks good to me", indicates that a PR is ready to be merged. label Aug 6, 2025
@mwmix
Copy link
Contributor Author

mwmix commented Aug 6, 2025

Ah I see the issue this isn't using the refactored stuff. I've re-based everything and pushed updates. I can build locally and run.

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.

/approve

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

[APPROVALNOTIFIER] This PR is APPROVED

This pull-request has been approved by: ivankatliarchuk

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 Aug 7, 2025
@k8s-ci-robot k8s-ci-robot merged commit 6bda906 into kubernetes-sigs:master Aug 7, 2025
14 checks passed
troll-os pushed a commit to FiligranHQ/external-dns that referenced this pull request Aug 28, 2025
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 <[email protected]>
Co-committed-by: JesusMtnez-bot <[email protected]>
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. docs internal Issues or PRs related to internal code lgtm "Looks good to me", indicates that a PR is ready to be merged. metrics Issues or PRs related to metrics ok-to-test Indicates a non-member PR verified by an org member that is safe to test. provider Issues or PRs related to a provider 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.

4 participants