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

Gateway object for korifi api uses protocol mode passthrough with TLS Protocol. Looks like Nginx gateway fabric does not support TLS protocol and passthrough? #3188

Open
doddisam opened this issue Mar 20, 2024 · 2 comments
Labels

Comments

@doddisam
Copy link

doddisam commented Mar 20, 2024

Background

Hello,

I switched the ingress controller to nginx from contour to test the different ingress controller which supports gateway api. I see it failing with below error when i target to korifi api.

Note:- The same Gateway configuration works with contour and looks like contour supports passthrough over TLS.

API endpoint: https://api.korifi-pks.amer.xxx.com
Request error: Get "https://api.korifi-pks.amer.xxx.com": remote error: tls: unrecognized name

image

After some research i found that nginx gateway fabric does not support passthrough with TLS protocol as of today.
image

Also i see below error on the Gateway object.
Attached Routes: 0
Conditions:
Last Transition Time: 2024-03-20T09:01:55Z
Message: protocol: Unsupported value: "TLS": supported values: "HTTP", "HTTPS"
Observed Generation: 6
Reason: UnsupportedProtocol
Status: False
Type: Accepted
Last Transition Time: 2024-03-20T09:01:55Z
Message: protocol: Unsupported value: "TLS": supported values: "HTTP", "HTTPS"
Observed Generation: 6
Reason: Invalid
Status: False
Type: Programmed
Name: https-api

Is there a way to get this working with nginx gateway fabric as of today ?

Action to take

No response

Impact

Hello,

I switched the ingress controller to nginx from contour to testing the gateway api compatibility. I see it failed with below error when i target to korifi api using nginx.

Note:- The same Gateway configuration works with contour and looks like contour supports passthrough over TLS.

API endpoint: https://api.korifi-pks.xxx.com
Request error: Get "https://api.korifi-pks.xxx.com": remote error: tls: unrecognized name

After some research i found that nginx gateway fabric does not support passthrough with TLS protocol as of today.
image

Also i see below error on the Gateway object.
Attached Routes: 0
Conditions:
Last Transition Time: 2024-03-20T09:01:55Z
Message: protocol: Unsupported value: "TLS": supported values: "HTTP", "HTTPS"
Observed Generation: 6
Reason: UnsupportedProtocol
Status: False
Type: Accepted
Last Transition Time: 2024-03-20T09:01:55Z
Message: protocol: Unsupported value: "TLS": supported values: "HTTP", "HTTPS"
Observed Generation: 6
Reason: Invalid
Status: False
Type: Programmed
Name: https-api

Is there a way to get this working with nginx gateway fabric as of today ?

Dev Notes

No response

@doddisam doddisam added the chore label Mar 20, 2024
@github-project-automation github-project-automation bot moved this to 🧊 Icebox in Korifi - Backlog Mar 20, 2024
@doddisam doddisam changed the title Gateway object for korifi api uses protocol TLS and mode passthrough. Looks like Nginx gateway fabric does not support TLS protocol and passthrough? Gateway object for korifi api uses protocol mode passthrough with TLS Protocol. Looks like Nginx gateway fabric does not support TLS protocol and passthrough? Mar 20, 2024
@danail-branekov
Copy link
Member

danail-branekov commented Mar 28, 2024

Hey @doddisam

Is there a way to get this working with nginx gateway fabric as of today ?

Unfortunately not out of the box. Previously we used to reencrypt requests to korifi api when sent to kubernetes but we gave this up in favour of Gateway API TLS passthrough. That worked well for the networkers we looked at (contour and istio) but apparently this is not supported by all implementations.

As a workaround you could experiment with patching the korifi gateway to get the reencryption working until nginx gateway starts supporting passthrough.

@doddisam
Copy link
Author

@danail-branekov Thank you for your response.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
Status: 🧊 Icebox
Development

No branches or pull requests

2 participants