<?php

$table = new PhabricatorAuditTransaction();
$conn = $table->establishConnection('w');

$status_map = array(
  0 => 'none',
  1 => 'needs-audit',
  2 => 'concern-raised',
  3 => 'partially-audited',
  4 => 'audited',
  5 => 'needs-verification',
);

$state_type = DiffusionCommitStateTransaction::TRANSACTIONTYPE;

foreach (new LiskMigrationIterator($table) as $xaction) {
  if ($xaction->getTransactionType() !== $state_type) {
    continue;
  }

  $old_value = $xaction->getOldValue();
  $new_value = $xaction->getNewValue();

  $any_change = false;

  if (isset($status_map[$old_value])) {
    $old_value = $status_map[$old_value];
    $any_change = true;
  }

  if (isset($status_map[$new_value])) {
    $new_value = $status_map[$new_value];
    $any_change = true;
  }

  if (!$any_change) {
    continue;
  }

  queryfx(
    $conn,
    'UPDATE %T SET oldValue = %s, newValue = %s WHERE id = %d',
    $table->getTableName(),
    phutil_json_encode($old_value),
    phutil_json_encode($new_value),
    $xaction->getID());
}