2013-07-29 01:55:13 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
$qtable = new PonderQuestionTransaction();
|
|
|
|
$atable = new PonderAnswerTransaction();
|
|
|
|
|
|
|
|
$conn_w = $qtable->establishConnection('w');
|
|
|
|
$conn_w->openTransaction();
|
|
|
|
|
|
|
|
echo "Migrating Ponder comments to ApplicationTransactions...\n";
|
|
|
|
|
|
|
|
$rows = new LiskRawMigrationIterator($conn_w, 'ponder_comment');
|
|
|
|
foreach ($rows as $row) {
|
|
|
|
|
|
|
|
$id = $row['id'];
|
|
|
|
echo "Migrating {$id}...\n";
|
|
|
|
|
|
|
|
$type = phid_get_type($row['targetPHID']);
|
|
|
|
switch ($type) {
|
2014-07-24 00:05:46 +02:00
|
|
|
case PonderQuestionPHIDType::TYPECONST:
|
2013-07-29 01:55:13 +02:00
|
|
|
$table_obj = $qtable;
|
|
|
|
$comment_obj = new PonderQuestionTransactionComment();
|
|
|
|
break;
|
2014-07-24 00:05:46 +02:00
|
|
|
case PonderAnswerPHIDType::TYPECONST:
|
2013-07-29 01:55:13 +02:00
|
|
|
$table_obj = $atable;
|
|
|
|
$comment_obj = new PonderAnswerTransactionComment();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
$comment_phid = PhabricatorPHID::generateNewPHID(
|
2014-07-24 00:05:46 +02:00
|
|
|
PhabricatorApplicationTransactionTransactionPHIDType::TYPECONST,
|
2013-07-29 01:55:13 +02:00
|
|
|
$type);
|
|
|
|
|
|
|
|
$xaction_phid = PhabricatorPHID::generateNewPHID(
|
2014-07-24 00:05:46 +02:00
|
|
|
PhabricatorApplicationTransactionTransactionPHIDType::TYPECONST,
|
2013-07-29 01:55:13 +02:00
|
|
|
$type);
|
|
|
|
|
|
|
|
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)',
|
|
|
|
$comment_obj->getTableName(),
|
|
|
|
$comment_phid,
|
|
|
|
$xaction_phid,
|
|
|
|
$row['authorPHID'],
|
|
|
|
'public',
|
|
|
|
$row['authorPHID'],
|
|
|
|
1,
|
|
|
|
$row['content'],
|
|
|
|
PhabricatorContentSource::newForSource(
|
|
|
|
PhabricatorContentSource::SOURCE_LEGACY,
|
|
|
|
array())->serialize(),
|
|
|
|
0,
|
|
|
|
$row['dateCreated'],
|
|
|
|
$row['dateModified']);
|
|
|
|
|
|
|
|
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, %ns, %ns, %s, %s, %d, %d)',
|
|
|
|
$table_obj->getTableName(),
|
|
|
|
$xaction_phid,
|
|
|
|
$row['authorPHID'],
|
|
|
|
$row['targetPHID'],
|
|
|
|
'public',
|
|
|
|
$row['authorPHID'],
|
|
|
|
$comment_phid,
|
|
|
|
1,
|
|
|
|
PhabricatorTransactions::TYPE_COMMENT,
|
|
|
|
'null',
|
|
|
|
'null',
|
|
|
|
PhabricatorContentSource::newForSource(
|
|
|
|
PhabricatorContentSource::SOURCE_LEGACY,
|
|
|
|
array())->serialize(),
|
|
|
|
'[]',
|
|
|
|
$row['dateCreated'],
|
|
|
|
$row['dateModified']);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
$conn_w->saveTransaction();
|
|
|
|
|
|
|
|
echo "Done.\n";
|