Page MenuHomePhabricator

Disable XML entity loader by default in libphutil
ClosedPublic

Authored by epriestley on Jan 23 2014, 9:32 PM.
Tags
None
Referenced Files
F19805416: D8049.id18207.diff
Mon, Mar 2, 10:49 PM
F19804975: D8049.id18207.diff
Mon, Mar 2, 5:16 PM
F19779924: D8049.diff
Mon, Feb 23, 6:00 PM
F19531857: D8049.id18207.diff
Jan 20 2026, 7:32 AM
F19531361: D8049.diff
Jan 20 2026, 4:13 AM
F19531360: D8049.diff
Jan 20 2026, 4:13 AM
F19527758: D8049.diff
Jan 19 2026, 4:11 AM
F19513349: D8049.id18204.diff
Jan 13 2026, 11:34 AM
Subscribers

Details

Summary

See https://www.facebook.com/BugBounty/posts/778897822124446 and http://www.ubercomp.com/posts/2014-01-16_facebook_remote_code_execution.

By default, SimpleXMLElement will pretty much just run whatever code you want when handed a specially crafted document. We currently load XML only from trusted (S3, EC2, git/svn/hg) or local sources (unit test runners) so there are no concrete vulnerabilities in Phabricator, but this behavior is incredibly dangerous, surprising, and highly undesirable.

Test Plan

There's an example of a document which does bad things on http://www.php.net/manual/en/function.libxml-disable-entity-loader.php. I verified that SimpleXMLElement reads /etc/passwd when handed this document, then applied the fix. It no longer reads arbitrary files off disk.

Diff Detail

Lint
Lint Skipped
Unit
Tests Skipped