Page MenuHomePhabricator

Remove PhabricatorFile::buildFromFileDataOrHash()
ClosedPublic

Authored by epriestley on Apr 4 2017, 9:32 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Dec 31, 8:53 PM
Unknown Object (File)
Mon, Dec 30, 12:31 AM
Unknown Object (File)
Dec 13 2024, 4:42 PM
Unknown Object (File)
Dec 9 2024, 12:53 PM
Unknown Object (File)
Nov 30 2024, 3:46 AM
Unknown Object (File)
Nov 27 2024, 6:59 PM
Unknown Object (File)
Nov 25 2024, 4:34 AM
Unknown Object (File)
Nov 23 2024, 12:00 AM
Subscribers

Details

Summary

Ref T12464. This is a very old method which can return an existing file instead of creating a new one, if there's some existing file with the same content.

In the best case this is a bad idea. This being somewhat reasonable predates policies, temporary files, etc. Modern methods like newFromFileData() do this right: they share underlying data in storage, but not the actual File records.

Specifically, this is the case where we get into trouble:

  • I upload a private file with content "X".
  • You somehow generate a file with the same content by, say, viewing a raw diff in Differential.
  • If the diff had the same content, you get my file, but you don't have permission to see it or whatever so everything breaks and is terrible.

Just get rid of this.

Test Plan
  • Generated an SSH key.
  • Viewed a raw diff in Differential.
  • (Did not test Phragment.)

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable