Fix: Handle failed gzip reader creation gracefully #748
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.
I've been seeing that, when a gziped response was returned by some backend where the client didn't actually Accept that encoding, the service raised a panic and it crashed.
The example that I was able to reproduce is by making the backend return a gzip response but making the request only accept
identity
requests.The panic produced is because the
gzip.NewReader
is unable to be created, so it returns a nil pointer; this nil pointer is then what causes the crash when trying to call the deferedreader.Close
function.Stacktrace:
Config for KrakenD to reproduce it
Minimal server: