Opened 5 years ago
Closed 5 years ago
#3244 closed bug (Fixed)
Use gzip content encoding only if supported by client
Reported by: | tkSimon | Owned by: | |
---|---|---|---|
Priority: | minor | Milestone: | 2.x |
Component: | Web UI | Version: | other (please specify) |
Keywords: | Cc: |
Description (last modified by )
At the moment deluge responds to requests for certain resource with gzip content encoding regardless of the requests accept-encoding
header. It should only use gzip encoding if supported by the client.
Personally, I wanted deluge to respond with uncompressed assets because i have an nginx reverse proxy in front of deluge that's doing brotli (and gzip compression,) and caching those. The issue being that nginx only compresses when the origin (deluge) sends them uncompressed. This is usually achieved by configuring nginx to not forward the accept-encoding header.
To reproduce, run: curl 127.0.0.1:8112/js/ext-extensions.js -o /dev/null -v
The response will have a "Content-Encoding: gzip" header, and it's payload will be gzipped even though the request doesn't contain an "Accpet-Encoding: gzip" header.
I created a PR to fix this: https://github.com/deluge-torrent/deluge/pull/232
Change History (3)
comment:1 by , 5 years ago
Component: | Unknown → Web UI |
---|---|
Description: | modified (diff) |
Milestone: | needs verified → 2.x |
comment:3 by , 5 years ago
Resolution: | → Fixed |
---|---|
Status: | new → closed |
Based on your use-case I agree that this would be good to fix.
Using the Twisted resource wrapper is a better way to do this and I have created a PR: https://github.com/deluge-torrent/deluge/pull/233
We should also only compress text and not images and that can be included in the changes.