[feat: gw api] Add secure HTTPRoute and mutual auth support for L7 Ga… #4259
Add this suggestion to a batch that can be applied as a single commit. This suggestion is invalid because no changes were made to the code. Suggestions cannot be applied while the pull request is closed. Suggestions cannot be applied while viewing a subset of changes. Only one suggestion per line can be applied in a batch. Add this suggestion to a batch that can be applied as a single commit. Applying suggestions on deleted lines is not supported. You must change the existing code in this line in order to create a valid suggestion. Outdated suggestions cannot be applied. This suggestion has been applied or marked resolved. Suggestions cannot be applied from pending reviews. Suggestions cannot be applied on multi-line comments. Suggestions cannot be applied while the pull request is queued to merge. Suggestion cannot be applied right now. Please check back later.
Add Mutual Authentication Support for Gateway API TLS
Overview
This PR adds support for Mutual Authentication (mTLS) to the AWS Load Balancer Controller's Gateway API implementation. The changes enable configuring mTLS on ALB listeners in multiple modes, enhance HTTPS route functionality, and provide comprehensive E2E tests for these new features.
Key Changes
1. Mutual Authentication Support for L7 Gateway
Added support for configuring mTLS on ALB listeners through Gateway API TLS configuration
Implemented three mTLS modes:
off: Client certificates not requested (default behavior)passthrough: Client certificates are requested but not verifiedverify: Client certificates are requested and validated against a trust store (tests to be added in future PR)2. Added Default for ALPNPolicy
ALPNpolicy configuration for TLS listeners with a default ofNone3. HTTP Verifier Enhancements
4. Test Framework Improvements
VerifyListenerMutualAuthenticationto validate mTLS configuration on listenersVerifyLoadBalancerListenerto incorporate mutual authentication verificationMutualAuthenticationExpectationstruct to enable verification of mTLS settings5. New End-to-End Tests
offandpassthroughmodesverifymode will be added in a future PR once a trust store is created in the prow accountTesting
The PR includes comprehensive E2E tests that verify:
offandpassthroughmodesEach test validates both the configuration application to AWS resources and the actual runtime behavior by making requests to the provisioned endpoints.
Future Work
A follow-up PR will add support for
verifymode testing, which requires creating a trust store in the test AWS account.Checklist
README.md, or thedocsdirectory)BONUS POINTS checklist: complete for good vibes and maybe prizes?! 🤯