mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-01 02:10:59 +01:00
34 lines
811 B
PHP
34 lines
811 B
PHP
|
<?php
|
||
|
|
||
|
echo "Migrating Differential unsubscribed users to edges...\n";
|
||
|
$table = new DifferentialRevision();
|
||
|
$table->openTransaction();
|
||
|
|
||
|
// We couldn't use new LiskMigrationIterator($table) because the $unsubscribed
|
||
|
// property gets deleted.
|
||
|
$revs = queryfx_all(
|
||
|
$table->establishConnection('w'),
|
||
|
'SELECT id, phid, unsubscribed FROM differential_revision');
|
||
|
|
||
|
foreach ($revs as $rev) {
|
||
|
echo ".";
|
||
|
|
||
|
$unsubscribed = json_decode($rev['unsubscribed']);
|
||
|
if (!$unsubscribed) {
|
||
|
continue;
|
||
|
}
|
||
|
|
||
|
$editor = new PhabricatorEdgeEditor();
|
||
|
$editor->setSuppressEvents(true);
|
||
|
foreach ($unsubscribed as $user_phid => $_) {
|
||
|
$editor->addEdge(
|
||
|
$rev['phid'],
|
||
|
PhabricatorEdgeConfig::TYPE_OBJECT_HAS_UNSUBSCRIBER,
|
||
|
$user_phid);
|
||
|
}
|
||
|
$editor->save();
|
||
|
}
|
||
|
|
||
|
$table->saveTransaction();
|
||
|
echo "Done.\n";
|