[DRAFT] [NEED FEEDBACK] Support websocket through envoy #13418
Closed
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.
This PR aim to implement websocket support, referenced here #8283 .
Rather than always enable the websocket support for everything (like in this old PR #9639), I've created a new
websocket
parameter which can be used whereverprotocol
can be used, usually when you specify the service protocol of the service or when you override the path.In this patch, websocket it's disabled by default.
Basic unit testing was added but I couldn't validate them since i couldn't perform a clean test run with intellij, make test or make test-docker.
I've manually tested in a 2 node server installation and envoy configuration gets created correctly and it's routing correctly.
Since this is the first time I approach consul codebase i ask, if possible, for guidance before committing more time, especially if the overall approach is correct.