mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-25 14:08:19 +01:00
47 lines
1.5 KiB
PHP
47 lines
1.5 KiB
PHP
|
<?php
|
||
|
|
||
|
// Before T12956, normal users could reorder (and disable) builtin queries.
|
||
|
// After that change, there is a single global order which can only be
|
||
|
// changed by administrators.
|
||
|
|
||
|
// This migration removes the rows which store individual reordering and
|
||
|
// disabling of queries. If a user had reordered queries in such a way that
|
||
|
// a builtin query was at the top of the list, we try to write a preference
|
||
|
// which pins that query as their default to minimize disruption.
|
||
|
|
||
|
$table = new PhabricatorNamedQuery();
|
||
|
$conn = $table->establishConnection('w');
|
||
|
|
||
|
$config_table = new PhabricatorNamedQueryConfig();
|
||
|
|
||
|
foreach (new LiskMigrationIterator($table) as $named_query) {
|
||
|
|
||
|
// If this isn't a builtin query, it isn't changing. Leave it alone.
|
||
|
if (!$named_query->getIsBuiltin()) {
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
// If the user reordered things but left a builtin query at the top, pin
|
||
|
// the query before we remove the row.
|
||
|
if ($named_query->getSequence() == 1) {
|
||
|
queryfx(
|
||
|
$conn,
|
||
|
'INSERT IGNORE INTO %T
|
||
|
(engineClassName, scopePHID, properties, dateCreated, dateModified)
|
||
|
VALUES
|
||
|
(%s, %s, %s, %d, %d)',
|
||
|
$config_table->getTableName(),
|
||
|
$named_query->getEngineClassName(),
|
||
|
$named_query->getUserPHID(),
|
||
|
phutil_json_encode(
|
||
|
array(
|
||
|
PhabricatorNamedQueryConfig::PROPERTY_PINNED =>
|
||
|
$named_query->getQueryKey(),
|
||
|
)),
|
||
|
PhabricatorTime::getNow(),
|
||
|
PhabricatorTime::getNow());
|
||
|
}
|
||
|
|
||
|
$named_query->delete();
|
||
|
}
|