Page MenuHomePhabricator

Implement new profile transform with amazing "error handling" feature
ClosedPublic

Authored by epriestley on May 12 2015, 5:55 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sat, Jan 11, 3:47 AM
Unknown Object (File)
Thu, Jan 9, 9:03 AM
Unknown Object (File)
Fri, Dec 27, 7:57 PM
Unknown Object (File)
Fri, Dec 27, 7:35 PM
Unknown Object (File)
Wed, Dec 25, 11:31 AM
Unknown Object (File)
Wed, Dec 25, 11:26 AM
Unknown Object (File)
Tue, Dec 24, 11:00 PM
Unknown Object (File)
Dec 8 2024, 4:44 PM
Subscribers
Tokens
"Doubloon" token, awarded by btrahan.

Details

Summary

Ref T7707. Ref T4406. Ref T2479. This implements the profile-style (fixed width and height) transforms in a modern way.

  • Added a "regnerate" feature to the support UI to make testing easier and surface errors.
  • Laboriously check errors from everything.
  • Fix the profile thumbnailing so it crops properly instead of leaving margins.
  • Also defuses the "gigantic white PNG" attack.

This doesn't handle the imagemagick case (for animated GIFs) yet.

Test Plan
  • Uploaded a variety of wide/narrow/small/large files and converted them into sensible profile pictures.
  • Tried to thumbnail some text files.
  • Set the pixel-size and file-size limits artificially small and hit them.
  • Used "regenerate" a bunch while testing the rest of this stuff.
  • Verified that non-regenerate flows still produce a default/placeholder image.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

epriestley retitled this revision from to Implement new profile transform with amazing "error handling" feature.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: btrahan.
btrahan edited edge metadata.
btrahan added inline comments.
src/applications/files/transform/PhabricatorFileImageTransform.php
38

nice

49–50

forgot about the details of this trap stuff. very boss!

This revision is now accepted and ready to land.May 12 2015, 6:32 PM

error handling is a great feature btw

This revision was automatically updated to reflect the committed changes.