1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-10 23:01:04 +01:00

Fix all query warnings in "arc unit --everything"

Summary:
Ref T13216. Ref T13217. Depends on D19800. This fixes all of the remaining query warnings that pop up when you run "arc unit --everything".

There's likely still quite a bit of stuff lurking around, but hopefully this covers a big set of the most common queries.

Test Plan: Ran `arc unit --everything`. Before change: lots of query warnings. After change: no query warnings.

Reviewers: amckinley

Reviewed By: amckinley

Maniphest Tasks: T13217, T13216

Differential Revision: https://secure.phabricator.com/D19801
This commit is contained in:
epriestley 2018-11-13 09:32:52 -08:00
parent 2f10d4adeb
commit 86fd204148
15 changed files with 121 additions and 59 deletions

View file

@ -115,8 +115,8 @@ final class PhabricatorConfigSchemaQuery extends Phobject {
'SELECT TABLE_SCHEMA, TABLE_NAME, COLUMN_NAME, CHARACTER_SET_NAME, 'SELECT TABLE_SCHEMA, TABLE_NAME, COLUMN_NAME, CHARACTER_SET_NAME,
COLLATION_NAME, COLUMN_TYPE, IS_NULLABLE, EXTRA COLLATION_NAME, COLUMN_TYPE, IS_NULLABLE, EXTRA
FROM INFORMATION_SCHEMA.COLUMNS FROM INFORMATION_SCHEMA.COLUMNS
WHERE (%Q)', WHERE %LO',
'('.implode(') OR (', $sql).')'); $sql);
$column_info = igroup($column_info, 'TABLE_SCHEMA'); $column_info = igroup($column_info, 'TABLE_SCHEMA');
} else { } else {
$column_info = array(); $column_info = array();

View file

@ -696,7 +696,7 @@ final class DiffusionCommitQuery
pht('No commit identifiers.')); pht('No commit identifiers.'));
} }
$where[] = '('.implode(' OR ', $sql).')'; $where[] = qsprintf($conn, '%LO', $sql);
} }
if ($this->auditIDs !== null) { if ($this->auditIDs !== null) {

View file

@ -10,12 +10,12 @@ final class DiffusionPathQuery extends Phobject {
} }
public function execute() { public function execute() {
$conn_r = id(new PhabricatorRepository())->establishConnection('r'); $conn = id(new PhabricatorRepository())->establishConnection('r');
$where = $this->buildWhereClause($conn_r); $where = $this->buildWhereClause($conn);
$results = queryfx_all( $results = queryfx_all(
$conn_r, $conn,
'SELECT * FROM %T %Q', 'SELECT * FROM %T %Q',
PhabricatorRepository::TABLE_PATH, PhabricatorRepository::TABLE_PATH,
$where); $where);
@ -23,20 +23,20 @@ final class DiffusionPathQuery extends Phobject {
return ipull($results, null, 'id'); return ipull($results, null, 'id');
} }
protected function buildWhereClause(AphrontDatabaseConnection $conn_r) { protected function buildWhereClause(AphrontDatabaseConnection $conn) {
$where = array(); $where = array();
if ($this->pathIDs) { if ($this->pathIDs) {
$where[] = qsprintf( $where[] = qsprintf(
$conn_r, $conn,
'id IN (%Ld)', 'id IN (%Ld)',
$this->pathIDs); $this->pathIDs);
} }
if ($where) { if ($where) {
return 'WHERE ('.implode(') AND (', $where).')'; return qsprintf($conn, 'WHERE %LA', $where);
} else { } else {
return ''; return qsprintf($conn, '');
} }
} }

View file

@ -391,7 +391,7 @@ final class PhabricatorFileQuery
$transform['transform']); $transform['transform']);
} }
} }
$where[] = qsprintf($conn, '(%Q)', implode(') OR (', $clauses)); $where[] = qsprintf($conn, '%LO', $clauses);
} }
if ($this->dateCreatedAfter !== null) { if ($this->dateCreatedAfter !== null) {

View file

@ -458,11 +458,14 @@ final class PhabricatorUser
} }
public function loadPrimaryEmail() { public function loadPrimaryEmail() {
$email = new PhabricatorUserEmail();
$conn = $email->establishConnection('r');
return $this->loadOneRelative( return $this->loadOneRelative(
new PhabricatorUserEmail(), $email,
'userPHID', 'userPHID',
'getPHID', 'getPHID',
'(isPrimary = 1)'); qsprintf($conn, '(isPrimary = 1)'));
} }

View file

@ -42,20 +42,12 @@ final class PhortuneAccountQuery
return $this; return $this;
} }
public function newResultObject() {
return new PhortuneAccount();
}
protected function loadPage() { protected function loadPage() {
$table = new PhortuneAccount(); return $this->loadStandardPage($this->newResultObject());
$conn = $table->establishConnection('r');
$rows = queryfx_all(
$conn,
'SELECT a.* FROM %T a %Q %Q %Q %Q',
$table->getTableName(),
$this->buildJoinClause($conn),
$this->buildWhereClause($conn),
$this->buildOrderClause($conn),
$this->buildLimitClause($conn));
return $table->loadAllFromArray($rows);
} }
protected function willFilterPage(array $accounts) { protected function willFilterPage(array $accounts) {
@ -73,39 +65,37 @@ final class PhortuneAccountQuery
return $accounts; return $accounts;
} }
protected function buildWhereClause(AphrontDatabaseConnection $conn) { protected function buildWhereClauseParts(AphrontDatabaseConnection $conn) {
$where = array(); $where = parent::buildWhereClauseParts($conn);
$where[] = $this->buildPagingClause($conn); if ($this->ids !== null) {
if ($this->ids) {
$where[] = qsprintf( $where[] = qsprintf(
$conn, $conn,
'a.id IN (%Ld)', 'a.id IN (%Ld)',
$this->ids); $this->ids);
} }
if ($this->phids) { if ($this->phids !== null) {
$where[] = qsprintf( $where[] = qsprintf(
$conn, $conn,
'a.phid IN (%Ls)', 'a.phid IN (%Ls)',
$this->phids); $this->phids);
} }
if ($this->memberPHIDs) { if ($this->memberPHIDs !== null) {
$where[] = qsprintf( $where[] = qsprintf(
$conn, $conn,
'm.dst IN (%Ls)', 'm.dst IN (%Ls)',
$this->memberPHIDs); $this->memberPHIDs);
} }
return $this->formatWhereClause($conn, $where); return $where;
} }
protected function buildJoinClause(AphrontDatabaseConnection $conn) { protected function buildJoinClauseParts(AphrontDatabaseConnection $conn) {
$joins = array(); $joins = parent::buildJoinClauseParts($conn);
if ($this->memberPHIDs) { if ($this->memberPHIDs !== null) {
$joins[] = qsprintf( $joins[] = qsprintf(
$conn, $conn,
'LEFT JOIN %T m ON a.phid = m.src AND m.type = %d', 'LEFT JOIN %T m ON a.phid = m.src AND m.type = %d',
@ -113,11 +103,15 @@ final class PhortuneAccountQuery
PhortuneAccountHasMemberEdgeType::EDGECONST); PhortuneAccountHasMemberEdgeType::EDGECONST);
} }
return implode(' ', $joins); return $joins;
} }
public function getQueryApplicationClass() { public function getQueryApplicationClass() {
return 'PhabricatorPhortuneApplication'; return 'PhabricatorPhortuneApplication';
} }
protected function getPrimaryTableAlias() {
return 'a';
}
} }

View file

@ -297,9 +297,9 @@ final class PhabricatorBoardLayoutEngine extends Phobject {
queryfx( queryfx(
$conn_w, $conn_w,
'INSERT INTO %T (id, sequence, boardPHID, columnPHID, objectPHID) 'INSERT INTO %T (id, sequence, boardPHID, columnPHID, objectPHID)
VALUES %Q ON DUPLICATE KEY UPDATE sequence = VALUES(sequence)', VALUES %LQ ON DUPLICATE KEY UPDATE sequence = VALUES(sequence)',
$table->getTableName(), $table->getTableName(),
implode(', ', $pairs)); $pairs);
} }
foreach ($adds as $position) { foreach ($adds as $position) {

View file

@ -557,7 +557,7 @@ final class PhabricatorProjectQuery
$ancestor_path['projectDepth']); $ancestor_path['projectDepth']);
} }
$where[] = '('.implode(' OR ', $sql).')'; $where[] = qsprintf($conn, '%LO', $sql);
$where[] = qsprintf( $where[] = qsprintf(
$conn, $conn,

View file

@ -513,8 +513,8 @@ final class PhabricatorRepositoryQuery
if ($this->shouldJoinURITable()) { if ($this->shouldJoinURITable()) {
$joins[] = qsprintf( $joins[] = qsprintf(
$conn, $conn,
'LEFT JOIN %T uri ON r.phid = uri.repositoryPHID', 'LEFT JOIN %R uri ON r.phid = uri.repositoryPHID',
id(new PhabricatorRepositoryURIIndex())->getTableName()); new PhabricatorRepositoryURIIndex());
} }
return $joins; return $joins;
@ -639,7 +639,7 @@ final class PhabricatorRepositoryQuery
$this->slugIdentifiers); $this->slugIdentifiers);
} }
$where = array('('.implode(' OR ', $identifier_clause).')'); $where[] = qsprintf($conn, '%LO', $identifier_clause);
} }
if ($this->types) { if ($this->types) {

View file

@ -70,9 +70,9 @@ abstract class PhabricatorRepositoryCommitChangeParserWorker
} }
queryfx( queryfx(
$conn_w, $conn_w,
'INSERT IGNORE INTO %T (path, pathHash) VALUES %Q', 'INSERT IGNORE INTO %T (path, pathHash) VALUES %LQ',
PhabricatorRepository::TABLE_PATH, PhabricatorRepository::TABLE_PATH,
implode(', ', $sql)); $sql);
} }
$result_map += self::lookupPaths($missing_paths); $result_map += self::lookupPaths($missing_paths);
} }

View file

@ -463,9 +463,9 @@ final class PhabricatorRepositorySvnCommitChangeParserWorker
$conn_w, $conn_w,
'INSERT INTO %T 'INSERT INTO %T
(repositoryID, parentID, svnCommit, pathID, existed, fileType) (repositoryID, parentID, svnCommit, pathID, existed, fileType)
VALUES %Q', VALUES %LQ',
PhabricatorRepository::TABLE_FILESYSTEM, PhabricatorRepository::TABLE_FILESYSTEM,
implode(', ', $sql_chunk)); $sql_chunk);
} }
} }

View file

@ -2353,7 +2353,7 @@ abstract class PhabricatorCursorPagedPolicyAwareQuery
(array)$constraint->getValue(), (array)$constraint->getValue(),
$idx++); $idx++);
} }
$parts = implode(', ', $parts); $parts = qsprintf($conn, '%LQ', $parts);
$select[] = qsprintf( $select[] = qsprintf(
$conn, $conn,

View file

@ -77,11 +77,20 @@ final class LiskDAOSet extends Phobject {
} else { } else {
$set = new LiskDAOSet(); $set = new LiskDAOSet();
$this->subsets[] = $set; $this->subsets[] = $set;
$conn = $object->establishConnection('r');
if (strlen($where)) {
$where_clause = qsprintf($conn, 'AND %Q', $where);
} else {
$where_clause = qsprintf($conn, '');
}
$relatives = $object->putInSet($set)->loadAllWhere( $relatives = $object->putInSet($set)->loadAllWhere(
'%C IN (%Ls) %Q', '%C IN (%Ls) %Q',
$foreign_column, $foreign_column,
$ids, $ids,
($where != '' ? 'AND '.$where : '')); $where_clause);
$relatives = mgroup($relatives, 'get'.$foreign_column); $relatives = mgroup($relatives, 'get'.$foreign_column);
} }
} }

View file

@ -265,7 +265,9 @@ final class PhabricatorStorageManagementAPI extends Phobject {
} }
try { try {
queryfx($conn, '%Q', $query); // NOTE: We're using the unsafe "%Z" conversion here. There's no
// avoiding it since we're executing raw text files full of SQL.
queryfx($conn, '%Z', $query);
} catch (AphrontAccessDeniedQueryException $ex) { } catch (AphrontAccessDeniedQueryException $ex) {
throw new PhutilProxyException( throw new PhutilProxyException(
pht( pht(

View file

@ -357,22 +357,76 @@ abstract class PhabricatorStorageManagementWorkflow
} }
if ($adjust['charset']) { if ($adjust['charset']) {
switch ($adjust['charset']) {
case 'binary':
$charset_value = qsprintf($conn, 'binary');
break;
case 'utf8':
$charset_value = qsprintf($conn, 'utf8');
break;
case 'utf8mb4':
$charset_value = qsprintf($conn, 'utf8mb4');
break;
default:
throw new Exception(
pht(
'Unsupported character set "%s".',
$adjust['charset']));
}
switch ($adjust['collation']) {
case 'binary':
$collation_value = qsprintf($conn, 'binary');
break;
case 'utf8_general_ci':
$collation_value = qsprintf($conn, 'utf8_general_ci');
break;
case 'utf8mb4_bin':
$collation_value = qsprintf($conn, 'utf8mb4_bin');
break;
case 'utf8mb4_unicode_ci':
$collation_value = qsprintf($conn, 'utf8mb4_unicode_ci');
break;
default:
throw new Exception(
pht(
'Unsupported collation set "%s".',
$adjust['collation']));
}
$parts[] = qsprintf( $parts[] = qsprintf(
$conn, $conn,
'CHARACTER SET %Q COLLATE %Q', 'CHARACTER SET %Q COLLATE %Q',
$adjust['charset'], $charset_value,
$adjust['collation']); $collation_value);
} }
if ($parts) {
$parts = qsprintf($conn, '%LJ', $parts);
} else {
$parts = qsprintf($conn, '');
}
if ($adjust['nullable']) {
$nullable = qsprintf($conn, 'NULL');
} else {
$nullable = qsprintf($conn, 'NOT NULL');
}
// TODO: We're using "%Z" here for the column type, which is
// technically unsafe. It would be nice to be able to use "%Q"
// instead, but this requires a fair amount of legwork to
// enumerate all column types.
queryfx( queryfx(
$conn, $conn,
'ALTER TABLE %T.%T MODIFY %T %Q %Q %Q', 'ALTER TABLE %T.%T MODIFY %T %Z %Q %Q',
$adjust['database'], $adjust['database'],
$adjust['table'], $adjust['table'],
$adjust['name'], $adjust['name'],
$adjust['type'], $adjust['type'],
implode(' ', $parts), $parts,
$adjust['nullable'] ? 'NULL' : 'NOT NULL'); $nullable);
} }
break; break;
case 'key': case 'key':
@ -395,7 +449,7 @@ abstract class PhabricatorStorageManagementWorkflow
// Different keys need different creation syntax. Notable // Different keys need different creation syntax. Notable
// special cases are primary keys and fulltext keys. // special cases are primary keys and fulltext keys.
if ($adjust['name'] == 'PRIMARY') { if ($adjust['name'] == 'PRIMARY') {
$key_name = 'PRIMARY KEY'; $key_name = qsprintf($conn, 'PRIMARY KEY');
} else if ($adjust['indexType'] == 'FULLTEXT') { } else if ($adjust['indexType'] == 'FULLTEXT') {
$key_name = qsprintf($conn, 'FULLTEXT %T', $adjust['name']); $key_name = qsprintf($conn, 'FULLTEXT %T', $adjust['name']);
} else { } else {
@ -414,11 +468,11 @@ abstract class PhabricatorStorageManagementWorkflow
queryfx( queryfx(
$conn, $conn,
'ALTER TABLE %T.%T ADD %Q (%Q)', 'ALTER TABLE %T.%T ADD %Q (%LK)',
$adjust['database'], $adjust['database'],
$adjust['table'], $adjust['table'],
$key_name, $key_name,
implode(', ', $adjust['columns'])); $adjust['columns']);
} }
break; break;
default: default: