Page MenuHomePhabricator

Don't combine automatic output compression with "Content-Length"
ClosedPublic

Authored by epriestley on Dec 13 2016, 10:07 PM.
Tags
None
Referenced Files
F18807298: D17045.id40997.diff
Sun, Oct 19, 12:28 AM
F18760176: D17045.id40997.diff
Mon, Oct 6, 8:22 AM
F18745944: D17045.id40997.diff
Fri, Oct 3, 10:28 AM
F18740289: D17045.diff
Thu, Oct 2, 1:57 AM
F18630772: D17045.id41000.diff
Sep 16 2025, 12:54 PM
F18622007: D17045.id40997.diff
Sep 15 2025, 10:10 AM
F18618348: D17045.id40998.diff
Sep 14 2025, 11:52 PM
F18500375: D17045.diff
Sep 4 2025, 9:02 PM
Subscribers

Details

Summary

Fixes T12013. Send either "Content-Length" or enable output compression, but not both.

Prefer compression for static resources (CSS, JS, etc).

Test Plan

Ran curl -v ..., no longer saw responses with both compression and Content-Length.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

epriestley retitled this revision from to Don't combine automatic output compression with "Content-Length".
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: chad.
avivey added inline comments.
src/aphront/response/AphrontFileResponse.php
134–136

maybe also enable the compression on else?

Yeahhhhh

src/aphront/response/AphrontFileResponse.php
134–136

It's enabled globally in PhabricatorStartup and I shudder to think what PHP might do if we enable it twice.

It would, perhaps, be cleaner to bring the CompressResponse stuff up a level to AphrontResponse, and have that control zlib.output_compression in all cases, although when we fatal the "¯\_(ツ)_/¯" page won't get compressed.

  • Centralize compression logic in one place, in AphrontResponse.
avivey added a reviewer: avivey.

Yeah, that looks like it will probably not PHP in new ways?

("PHP" in that sentence is short for "break in interesting ways").

This revision is now accepted and ready to land.Dec 13 2016, 10:23 PM

Hahaha. Yeah, this feels a little more solid.

This revision was automatically updated to reflect the committed changes.