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:
parent
1706212e24
commit
140927926d
2 changed files with 30 additions and 32 deletions
|
@ -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)
|
||||||
|
|
|
@ -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:
|
||||||
|
|
Loading…
Reference in a new issue