Add and populate a pathIndex
column for OwnersPath
Summary: Ref T11015. This supports making path names arbitrarily long and putting a proper unique key on the table. Test Plan: - Migrated, checked database, saw nice digested indexes. - Edited a package, saw new rows update with digested indexes. Maniphest Tasks: T11015 Differential Revision: https://secure.phabricator.com/D19181
This commit is contained in:
2
resources/sql/autopatches/20180306.opath.01.digest.sql
Normal file
2
resources/sql/autopatches/20180306.opath.01.digest.sql
Normal file
@@ -0,0 +1,2 @@
|
||||
ALTER TABLE {$NAMESPACE}_owners.owners_path
|
||||
ADD pathIndex BINARY(12) NOT NULL;
|
@@ -0,0 +1,19 @@
|
||||
<?php
|
||||
|
||||
$table = new PhabricatorOwnersPath();
|
||||
$conn = $table->establishConnection('w');
|
||||
|
||||
foreach (new LiskMigrationIterator($table) as $path) {
|
||||
$index = PhabricatorHash::digestForIndex($path->getPath());
|
||||
|
||||
if ($index === $path->getPathIndex()) {
|
||||
continue;
|
||||
}
|
||||
|
||||
queryfx(
|
||||
$conn,
|
||||
'UPDATE %T SET pathIndex = %s WHERE id = %d',
|
||||
$table->getTableName(),
|
||||
$index,
|
||||
$path->getID());
|
||||
}
|
@@ -4,6 +4,7 @@ final class PhabricatorOwnersPath extends PhabricatorOwnersDAO {
|
||||
|
||||
protected $packageID;
|
||||
protected $repositoryPHID;
|
||||
protected $pathIndex;
|
||||
protected $path;
|
||||
protected $excluded;
|
||||
|
||||
@@ -15,6 +16,7 @@ final class PhabricatorOwnersPath extends PhabricatorOwnersDAO {
|
||||
self::CONFIG_TIMESTAMPS => false,
|
||||
self::CONFIG_COLUMN_SCHEMA => array(
|
||||
'path' => 'text255',
|
||||
'pathIndex' => 'bytes12',
|
||||
'excluded' => 'bool',
|
||||
),
|
||||
self::CONFIG_KEY_SCHEMA => array(
|
||||
@@ -25,12 +27,17 @@ final class PhabricatorOwnersPath extends PhabricatorOwnersDAO {
|
||||
) + parent::getConfiguration();
|
||||
}
|
||||
|
||||
|
||||
public static function newFromRef(array $ref) {
|
||||
$path = new PhabricatorOwnersPath();
|
||||
$path->repositoryPHID = $ref['repositoryPHID'];
|
||||
$path->path = $ref['path'];
|
||||
|
||||
$raw_path = $ref['path'];
|
||||
|
||||
$path->pathIndex = PhabricatorHash::digestForIndex($raw_path);
|
||||
$path->path = $raw_path;
|
||||
|
||||
$path->excluded = $ref['excluded'];
|
||||
|
||||
return $path;
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user