mirror of
https://we.phorge.it/source/phorge.git
synced 2025-01-25 05:58:21 +01:00
601aaa5a86
Summary: Ref T10537. For Nuance, I want to introduce new sources (like "GitHub" or "GitHub via Nuance" or something) but this needs to modularize eventually. Split ContentSource apart so applications can add new content sources. Test Plan: This change has huge surface area, so I'll hold it until post-release. I think it's fairly safe (and if it does break anything, the breaks should be fatals, not anything subtle or difficult to fix), there's just no reason not to hold it for a few hours. - Viewed new module page. - Grepped for all removed functions/constants. - Viewed some transactions. - Hovered over timestamps to get content source details. - Added a comment via Conduit. - Added a comment via web. - Ran `bin/storage upgrade --namespace XXXXX --no-quickstart -f` to re-run all historic migrations. - Generated some objects with `bin/lipsum`. - Ran a bulk job on some tasks. - Ran unit tests. {F1190182} Reviewers: chad Reviewed By: chad Maniphest Tasks: T10537 Differential Revision: https://secure.phabricator.com/D15521
100 lines
2.6 KiB
PHP
100 lines
2.6 KiB
PHP
<?php
|
|
|
|
echo pht('Moving Slowvote comments to transactions...')."\n";
|
|
|
|
$viewer = PhabricatorUser::getOmnipotentUser();
|
|
|
|
$table_xaction = new PhabricatorSlowvoteTransaction();
|
|
$table_comment = new PhabricatorSlowvoteTransactionComment();
|
|
$conn_w = $table_xaction->establishConnection('w');
|
|
|
|
$comments = new LiskRawMigrationIterator($conn_w, 'slowvote_comment');
|
|
|
|
$conn_w->openTransaction();
|
|
|
|
foreach ($comments as $comment) {
|
|
$id = $comment['id'];
|
|
$poll_id = $comment['pollID'];
|
|
$author_phid = $comment['authorPHID'];
|
|
$text = $comment['commentText'];
|
|
$date_created = $comment['dateCreated'];
|
|
$date_modified = $comment['dateModified'];
|
|
|
|
echo pht('Migrating comment %d.', $id)."\n";
|
|
|
|
$poll = id(new PhabricatorSlowvoteQuery())
|
|
->setViewer($viewer)
|
|
->withIDs(array($poll_id))
|
|
->executeOne();
|
|
if (!$poll) {
|
|
echo pht('No poll.')."\n";
|
|
continue;
|
|
}
|
|
|
|
$user = id(new PhabricatorPeopleQuery())
|
|
->setViewer($viewer)
|
|
->withPHIDs(array($author_phid))
|
|
->executeOne();
|
|
if (!$user) {
|
|
echo pht('No user.')."\n";
|
|
continue;
|
|
}
|
|
|
|
$comment_phid = PhabricatorPHID::generateNewPHID(
|
|
PhabricatorPHIDConstants::PHID_TYPE_XCMT);
|
|
$xaction_phid = PhabricatorPHID::generateNewPHID(
|
|
PhabricatorApplicationTransactionTransactionPHIDType::TYPECONST,
|
|
PhabricatorSlowvotePollPHIDType::TYPECONST);
|
|
|
|
$content_source = PhabricatorContentSource::newForSource(
|
|
PhabricatorOldWorldContentSource::SOURCECONST)->serialize();
|
|
|
|
queryfx(
|
|
$conn_w,
|
|
'INSERT INTO %T (phid, transactionPHID, authorPHID, viewPolicy, editPolicy,
|
|
commentVersion, content, contentSource, isDeleted,
|
|
dateCreated, dateModified)
|
|
VALUES (%s, %s, %s, %s, %s,
|
|
%d, %s, %s, %d,
|
|
%d, %d)',
|
|
$table_comment->getTableName(),
|
|
$comment_phid,
|
|
$xaction_phid,
|
|
$user->getPHID(),
|
|
PhabricatorPolicies::POLICY_PUBLIC,
|
|
$user->getPHID(),
|
|
1,
|
|
$text,
|
|
$source,
|
|
0,
|
|
$date_created,
|
|
$date_modified);
|
|
|
|
queryfx(
|
|
$conn_w,
|
|
'INSERT INTO %T (phid, authorPHID, objectPHID, viewPolicy, editPolicy,
|
|
commentPHID, commentVersion, transactionType, oldValue, newValue,
|
|
contentSource, metadata, dateCreated, dateModified)
|
|
VALUES (%s, %s, %s, %s, %s,
|
|
%s, %d, %s, %s, %s,
|
|
%s, %s, %d, %d)',
|
|
$table_xaction->getTableName(),
|
|
$xaction_phid,
|
|
$user->getPHID(),
|
|
$poll->getPHID(),
|
|
PhabricatorPolicies::POLICY_PUBLIC,
|
|
$user->getPHID(),
|
|
$comment_phid,
|
|
1,
|
|
PhabricatorTransactions::TYPE_COMMENT,
|
|
null,
|
|
null,
|
|
$source,
|
|
'{}',
|
|
$date_created,
|
|
$date_modified);
|
|
}
|
|
|
|
$conn_w->saveTransaction();
|
|
|
|
echo pht('Done.')."\n";
|