-
Notifications
You must be signed in to change notification settings - Fork 1.1k
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
Merging to release-5.6: [TT-13088] Fixed godoc for path prefix and sufix configs (#6610) #6612
Merging to release-5.6: [TT-13088] Fixed godoc for path prefix and sufix configs (#6610) #6612
Conversation
(cherry picked from commit 68a6489)
Let's make that PR title a 💯 shall we? 💪 Your PR title and story title look slightly different. Just checking in to know if it was intentional!
Check out this guide to learn more about PR best-practices. |
API Changes --- prev.txt 2024-10-08 12:39:36.193952214 +0000
+++ current.txt 2024-10-08 12:39:32.873925364 +0000
@@ -5905,9 +5905,42 @@
// Regular expressions and parameterized routes will be left alone regardless of this setting.
EnableStrictRoutes bool `json:"enable_strict_routes"`
+ // EnablePathPrefixMatching changes how the gateway matches incoming URL paths against routes (patterns) defined in the API definition.
+ // By default, the gateway uses wildcard matching. When EnablePathPrefixMatching is enabled, it switches to prefix matching. For example, a defined path such as `/json` will only match request URLs that begin with `/json`, rather than matching any URL containing `/json`.
+ //
+ // The gateway checks the request URL against several variations depending on whether path versioning is enabled:
+ // - Full path (listen path + version + endpoint): `/listen-path/v4/json`
+ // - Non-versioned full path (listen path + endpoint): `/listen-path/json`
+ // - Path without version (endpoint only): `/json`
+ //
+ // For patterns that start with `/`, the gateway prepends `^` before performing the check, ensuring a true prefix match.
+ // For patterns that start with `^`, the gateway will already perform prefix matching so EnablePathPrefixMatching will have no impact.
+ // This option allows for more specific and controlled routing of API requests, potentially reducing unintended matches. Note that you may need to adjust existing route definitions when enabling this option.
+ //
+ // Example:
+ //
+ // With wildcard matching, `/json` might match `/api/v1/data/json`.
+ // With prefix matching, `/json` would not match `/api/v1/data/json`, but would match `/json/data`.
+ //
// Combining EnablePathPrefixMatching with EnablePathSuffixMatching will result in exact URL matching, with `/json` being evaluated as `^/json$`.
EnablePathPrefixMatching bool `json:"enable_path_prefix_matching"`
+ // EnablePathSuffixMatching changes how the gateway matches incoming URL paths against routes (patterns) defined in the API definition.
+ // By default, the gateway uses wildcard matching. When EnablePathSuffixMatching is enabled, it switches to suffix matching. For example, a defined path such as `/json` will only match request URLs that end with `/json`, rather than matching any URL containing `/json`.
+ //
+ // The gateway checks the request URL against several variations depending on whether path versioning is enabled:
+ // - Full path (listen path + version + endpoint): `/listen-path/v4/json`
+ // - Non-versioned full path (listen path + endpoint): `/listen-path/json`
+ // - Path without version (endpoint only): `/json`
+ //
+ // For patterns that already end with `$`, the gateway will already perform suffix matching so EnablePathSuffixMatching will have no impact. For all other patterns, the gateway appends `$` before performing the check, ensuring a true suffix match.
+ // This option allows for more specific and controlled routing of API requests, potentially reducing unintended matches. Note that you may need to adjust existing route definitions when enabling this option.
+ //
+ // Example:
+ //
+ // With wildcard matching, `/json` might match `/api/v1/json/data`.
+ // With suffix matching, `/json` would not match `/api/v1/json/data`, but would match `/api/v1/json`.
+ //
// Combining EnablePathSuffixMatching with EnablePathPrefixMatching will result in exact URL matching, with `/json` being evaluated as `^/json$`.
EnablePathSuffixMatching bool `json:"enable_path_suffix_matching"`
|
Failed to generate code suggestions for PR |
Quality Gate passedIssues Measures |
TT-13088
TT-13088 Fixed godoc for path prefix and sufix configs (#6610)