-
Notifications
You must be signed in to change notification settings - Fork 2.6k
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
feat(Gateway API): improve annotations support #4870
base: master
Are you sure you want to change the base?
feat(Gateway API): improve annotations support #4870
Conversation
[APPROVALNOTIFIER] This PR is NOT APPROVED This pull-request has been approved by: The full list of commands accepted by this bot can be found here.
Needs approval from an approver in each of these files:
Approvers can indicate their approval by writing |
Welcome @Dadeos-Menlo! |
Hi @Dadeos-Menlo. 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 Once the patch is verified, the new status will be reflected by the 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. |
/ok-to-test |
@abursavich do you think you can do a first review on this PR ? |
4a62691
to
b632a81
Compare
b632a81
to
cc10e6d
Compare
What additional documentation do you feel would add clarity? In my opinion the proposed changes merely bring the implementation in line with the existing documentation.
|
In current documentation, the behavior when there are annotations on both Gateway & HTTPRoute is not detailed: no explanation and no example. |
/retitle feat(Gateway API): improve annotations support |
Description
The generation of DNS records from Gateway API resources involves combining information from a …Route resource and a Gateway resource. The current implementation, for the most part, only considers annotations from the Route resource. There are potential scenarios whereby it may be more convenient to assign annotations to the Gateway resource, thus ensuring that all DNS records associated with the given Gateway are similarly effected. An extreme example of such a scenario being when no Hostname information is specified (i.e. the given Gateway should accept any communication, irrespective of the DNS name used to establish it) but that a DNS record is desired to cover all Routes associated with the Gateway; in which case it would be convenient to apply an
external-dns.alpha.kubernetes.io/hostname
annotation to the Gateway itself, rather than having to apply annotations to every associated Route and having to deal with the potential confusion arising from precisely which Route owns the shared DNS record.The proposed changes include:
resource
endpoint label ownership to all of the Gateway related unit-testsEndpoint
generation in order to preserve the relationship between Route and Gateway resourcesEndpoint
external-dns.alpha.kubernetes.io/ttl
annotations are merged to yield the lowest specified valueexternal-dns.alpha.kubernetes.io/hostname
is specified on a Gateway and that Gateway is the only Gateway contributing to anEndpoint
the resource label is recorded as referring to the Gateway rather than the RouteNo changes to the documentation are proposed because it currently implies that annotations on Gateway resources are supported, whereas in reality such annotations are only honoured when specified on Route resources.
Checklist