1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2024-11-29 18:22:41 +01:00

Improve utilization of "AuthTemporaryToken" table keys in LFS authentication queries

Summary:
See PHI1123. The key on this table is `<resource, type, code>` but we currently query for only `<type, code>`. This can't use the key.

Constrain the query to the resource we expect (the repository) so it can use the key.

Test Plan: Pushed files using LFS. See PHI1123 for more, likely.

Reviewers: amckinley

Reviewed By: amckinley

Differential Revision: https://secure.phabricator.com/D20261
This commit is contained in:
epriestley 2019-03-07 08:27:36 -08:00
parent 950a7bbb19
commit 9913754a2a

View file

@ -192,7 +192,10 @@ final class DiffusionServeController extends DiffusionController {
// Try Git LFS auth first since we can usually reject it without doing // Try Git LFS auth first since we can usually reject it without doing
// any queries, since the username won't match the one we expect or the // any queries, since the username won't match the one we expect or the
// request won't be LFS. // request won't be LFS.
$viewer = $this->authenticateGitLFSUser($username, $password); $viewer = $this->authenticateGitLFSUser(
$username,
$password,
$identifier);
// If that failed, try normal auth. Note that we can use normal auth on // If that failed, try normal auth. Note that we can use normal auth on
// LFS requests, so this isn't strictly an alternative to LFS auth. // LFS requests, so this isn't strictly an alternative to LFS auth.
@ -655,7 +658,8 @@ final class DiffusionServeController extends DiffusionController {
private function authenticateGitLFSUser( private function authenticateGitLFSUser(
$username, $username,
PhutilOpaqueEnvelope $password) { PhutilOpaqueEnvelope $password,
$identifier) {
// Never accept these credentials for requests which aren't LFS requests. // Never accept these credentials for requests which aren't LFS requests.
if (!$this->getIsGitLFSRequest()) { if (!$this->getIsGitLFSRequest()) {
@ -668,11 +672,31 @@ final class DiffusionServeController extends DiffusionController {
return null; return null;
} }
// See PHI1123. We need to be able to constrain the token query with
// "withTokenResources(...)" to take advantage of the key on the table.
// In this case, the repository PHID is the "resource" we're after.
// In normal workflows, we figure out the viewer first, then use the
// viewer to load the repository, but that won't work here. Load the
// repository as the omnipotent viewer, then use the repository PHID to
// look for a token.
$omnipotent_viewer = PhabricatorUser::getOmnipotentUser();
$repository = id(new PhabricatorRepositoryQuery())
->setViewer($omnipotent_viewer)
->withIdentifiers(array($identifier))
->executeOne();
if (!$repository) {
return null;
}
$lfs_pass = $password->openEnvelope(); $lfs_pass = $password->openEnvelope();
$lfs_hash = PhabricatorHash::weakDigest($lfs_pass); $lfs_hash = PhabricatorHash::weakDigest($lfs_pass);
$token = id(new PhabricatorAuthTemporaryTokenQuery()) $token = id(new PhabricatorAuthTemporaryTokenQuery())
->setViewer(PhabricatorUser::getOmnipotentUser()) ->setViewer($omnipotent_viewer)
->withTokenResources(array($repository->getPHID()))
->withTokenTypes(array(DiffusionGitLFSTemporaryTokenType::TOKENTYPE)) ->withTokenTypes(array(DiffusionGitLFSTemporaryTokenType::TOKENTYPE))
->withTokenCodes(array($lfs_hash)) ->withTokenCodes(array($lfs_hash))
->withExpired(false) ->withExpired(false)
@ -682,7 +706,7 @@ final class DiffusionServeController extends DiffusionController {
} }
$user = id(new PhabricatorPeopleQuery()) $user = id(new PhabricatorPeopleQuery())
->setViewer(PhabricatorUser::getOmnipotentUser()) ->setViewer($omnipotent_viewer)
->withPHIDs(array($token->getUserPHID())) ->withPHIDs(array($token->getUserPHID()))
->executeOne(); ->executeOne();