Page MenuHomePhabricator

Lock MIME type configuration
ClosedPublic

Authored by epriestley on Mar 25 2015, 11:13 AM.
Tags
None
Referenced Files
F18773734: D12154.id.diff
Thu, Oct 9, 12:15 PM
F18706199: D12154.id.diff
Sun, Sep 28, 3:55 PM
F18701080: D12154.diff
Sat, Sep 27, 5:13 PM
F18699135: D12154.id29226.diff
Sat, Sep 27, 12:29 PM
F18626263: D12154.id29216.diff
Sep 16 2025, 12:53 AM
F18623178: D12154.id29216.diff
Sep 15 2025, 2:37 PM
F18588971: D12154.diff
Sep 12 2025, 2:02 AM
F18505227: D12154.id.diff
Sep 5 2025, 12:30 AM
Subscribers

Details

Summary

Ref T6755. This mitigates an attack where you:

  • compromise an administrative account;
  • configure "text/plain" as an "image" MIME type; and
  • create a new macro sourced from a sensitive resource which is locally accessible over HTTP GET, using DNS rebinding.

You can then view the content of the resource in Files. By preventing the compromised account from reconfiguring the MIME types, the server will instead destroy the response and prevent the attacker from seeing it.

In general, these options should change very rarely, and they often sit just beyond the edge of security vulnerabilities anyway.

For example, if you ignore the warnings about an alternate file domain and elect to serve content from the primary domain, it's still somewhat difficult for an attacker to exploit the vulnerability. If they can add "text/html" or "image/svg+xml" as image MIME types, it becomes trivial. In this case not having an alternate domain is the main issue, but easy modification of this config increases risk/exposure.

Test Plan

Viewed affected config and saw that it is locked.

Diff Detail

Repository
rP Phabricator
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

epriestley retitled this revision from to Lock MIME type configuration.
epriestley updated this object.
epriestley edited the test plan for this revision. (Show Details)
epriestley added a reviewer: btrahan.
btrahan edited edge metadata.
This revision is now accepted and ready to land.Mar 25 2015, 4:57 PM
This revision was automatically updated to reflect the committed changes.