mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-11 07:11:04 +01:00
Don't require POST to download LFS files from main domain
Summary: Ref T7789. If you don't have `security.alternate-file-domain` configured, we won't serve binary files over GET. This is a security measure intended to prevent `<applet src="..." />` attacks and similar, where you upload some "dangerous" binary, include it in another page, and it gets some of the host's permissions because Java/Flash security models are (or were, in the past) goofy. Allow them to be served over GET if the client is Git LFS. This is safe; these attacks can't add arbitrary HTTP headers. Test Plan: Fetched files over GET with and without the LFS header. ``` $ curl -v http://local.phacility.com/file/data/@local/jfht2cxjazi5cmjomfhl/PHID-FILE-sa7mh2pfaocz2adiimeh/netgear_rma.pdf > /dev/null ... HTTP 302 Redirect ... ``` ``` $ curl -v -H 'X-Phabricator-Request-Type: git-lfs' http://localcontent.phacility.com/file/data/@local/jfht2cxjazi5cmjomfhl/PHID-FILE-sa7mh2pfaocz2adiimeh/netgear_rma.pdf > /dev/null ... HTTP 200 Content ... ``` Reviewers: chad Reviewed By: chad Maniphest Tasks: T7789 Differential Revision: https://secure.phabricator.com/D15654
This commit is contained in:
parent
27104b57c8
commit
37b93f4262
2 changed files with 5 additions and 1 deletions
|
@ -996,6 +996,7 @@ final class DiffusionServeController extends DiffusionController {
|
||||||
'href' => $get_uri,
|
'href' => $get_uri,
|
||||||
'header' => array(
|
'header' => array(
|
||||||
'Authorization' => $no_authorization,
|
'Authorization' => $no_authorization,
|
||||||
|
'X-Phabricator-Request-Type' => 'git-lfs',
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -82,10 +82,13 @@ final class PhabricatorFileDataController extends PhabricatorFileController {
|
||||||
$is_viewable = $file->isViewableInBrowser();
|
$is_viewable = $file->isViewableInBrowser();
|
||||||
$force_download = $request->getExists('download');
|
$force_download = $request->getExists('download');
|
||||||
|
|
||||||
|
$request_type = $request->getHTTPHeader('X-Phabricator-Request-Type');
|
||||||
|
$is_lfs = ($request_type == 'git-lfs');
|
||||||
|
|
||||||
if ($is_viewable && !$force_download) {
|
if ($is_viewable && !$force_download) {
|
||||||
$response->setMimeType($file->getViewableMimeType());
|
$response->setMimeType($file->getViewableMimeType());
|
||||||
} else {
|
} else {
|
||||||
if (!$request->isHTTPPost() && !$is_alternate_domain) {
|
if (!$request->isHTTPPost() && !$is_alternate_domain && !$is_lfs) {
|
||||||
// NOTE: Require POST to download files from the primary domain. We'd
|
// NOTE: Require POST to download files from the primary domain. We'd
|
||||||
// rather go full-bore and do a real CSRF check, but can't currently
|
// rather go full-bore and do a real CSRF check, but can't currently
|
||||||
// authenticate users on the file domain. This should blunt any
|
// authenticate users on the file domain. This should blunt any
|
||||||
|
|
Loading…
Reference in a new issue