1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-20 11:41:08 +01:00

Use a join instead of an awkward, weird query in PhabricatorAuditListController

Summary:
  - Use a join to effect this query.
  - Fixes a bug where packages with no commits would raise an exception because of the awkward query construction.
  - Fixes a bug on audit views.

Test Plan:
  - Viewed a package with no commits.
  - Altered audit filters.

Reviewers: btrahan, 20after4

Reviewed By: 20after4

CC: aran, epriestley

Maniphest Tasks: T904

Differential Revision: https://secure.phabricator.com/D1801
This commit is contained in:
epriestley 2012-03-06 19:47:53 -08:00
parent 1706212e24
commit 140927926d
2 changed files with 30 additions and 32 deletions

View file

@ -36,7 +36,7 @@ final class PhabricatorAuditListController extends PhabricatorAuditController {
// If the list filter is POST'ed, redirect to GET so the page can be // If the list filter is POST'ed, redirect to GET so the page can be
// bookmarked. // bookmarked.
$uri = $request->getRequestURI(); $uri = $request->getRequestURI();
$phid = head($request->getArr('phid')); $phid = head($request->getArr('set_phid'));
$user = id(new PhabricatorUser())->loadOneWhere( $user = id(new PhabricatorUser())->loadOneWhere(
'phid = %s', 'phid = %s',
$phid); $phid);
@ -172,7 +172,7 @@ final class PhabricatorAuditListController extends PhabricatorAuditController {
$form->appendChild( $form->appendChild(
id(new AphrontFormTokenizerControl()) id(new AphrontFormTokenizerControl())
->setName('phid') ->setName('set_phid')
->setLabel($label) ->setLabel($label)
->setLimit(1) ->setLimit(1)
->setDatasource($uri) ->setDatasource($uri)

View file

@ -23,7 +23,6 @@ final class PhabricatorAuditCommitQuery {
private $authorPHIDs; private $authorPHIDs;
private $packagePHIDs; private $packagePHIDs;
private $packageConstraint;
private $needCommitData; private $needCommitData;
@ -63,39 +62,19 @@ final class PhabricatorAuditCommitQuery {
public function execute() { public function execute() {
if ($this->packagePHIDs) {
// TODO: This is an odd, awkward query plan because these rows aren't
// on the same database as the commits. Once they're migrated we can
// resolve this via JOIN.
// TODO: Clean this up now that we've moved the table.
$table = new PhabricatorRepositoryAuditRequest();
$conn_r = $table->establishConnection('r');
$phids = queryfx_all(
$conn_r,
'SELECT DISTINCT commitPHID FROM %T WHERE auditorPHID IN (%Ls)
ORDER BY id DESC %Q',
$table->getTableName(),
$this->packagePHIDs,
$this->buildLimitClause($conn_r));
$this->packageConstraint = ipull($phids, 'commitPHID');
$this->limit = null;
$this->offset = null;
}
$table = new PhabricatorRepositoryCommit(); $table = new PhabricatorRepositoryCommit();
$conn_r = $table->establishConnection('r'); $conn_r = $table->establishConnection('r');
$join = $this->buildJoinClause($conn_r);
$where = $this->buildWhereClause($conn_r); $where = $this->buildWhereClause($conn_r);
$order = $this->buildOrderClause($conn_r); $order = $this->buildOrderClause($conn_r);
$limit = $this->buildLimitClause($conn_r); $limit = $this->buildLimitClause($conn_r);
$data = queryfx_all( $data = queryfx_all(
$conn_r, $conn_r,
'SELECT * FROM %T %Q %Q %Q', 'SELECT c.* FROM %T c %Q %Q %Q %Q',
$table->getTableName(), $table->getTableName(),
$join,
$where, $where,
$order, $order,
$limit); $limit);
@ -121,7 +100,26 @@ final class PhabricatorAuditCommitQuery {
} }
private function buildOrderClause($conn_r) { private function buildOrderClause($conn_r) {
return 'ORDER BY epoch DESC'; return 'ORDER BY c.epoch DESC';
}
private function buildJoinClause($conn_r) {
$join = array();
if ($this->packagePHIDs) {
$join[] = qsprintf(
$conn_r,
'JOIN %T req ON c.phid = req.commitPHID',
id(new PhabricatorRepositoryAuditRequest())->getTableName());
}
if ($join) {
$join = implode(' ', $join);
} else {
$join = '';
}
return $join;
} }
private function buildWhereClause($conn_r) { private function buildWhereClause($conn_r) {
@ -130,15 +128,15 @@ final class PhabricatorAuditCommitQuery {
if ($this->authorPHIDs) { if ($this->authorPHIDs) {
$where[] = qsprintf( $where[] = qsprintf(
$conn_r, $conn_r,
'authorPHID IN (%Ls)', 'c.authorPHID IN (%Ls)',
$this->authorPHIDs); $this->authorPHIDs);
} }
if ($this->packageConstraint !== null) { if ($this->packagePHIDs) {
$where[] = qsprintf( $where[] = qsprintf(
$conn_r, $conn_r,
'phid IN (%Ls)', 'req.auditorPHID in (%Ls)',
$this->packageConstraint); $this->packagePHIDs);
} }
$status = $this->status; $status = $this->status;
@ -146,7 +144,7 @@ final class PhabricatorAuditCommitQuery {
case self::STATUS_OPEN: case self::STATUS_OPEN:
$where[] = qsprintf( $where[] = qsprintf(
$conn_r, $conn_r,
'auditStatus = %s', 'c.auditStatus = %s',
PhabricatorAuditCommitStatusConstants::CONCERN_RAISED); PhabricatorAuditCommitStatusConstants::CONCERN_RAISED);
break; break;
case self::STATUS_ANY: case self::STATUS_ANY: