<?php $table = new PhabricatorRepositoryVCSPassword(); $conn_w = $table->establishConnection('w'); echo pht('Upgrading password hashing for VCS passwords.')."\n"; $best_hasher = PhabricatorPasswordHasher::getBestHasher(); foreach (new LiskMigrationIterator($table) as $password) { $id = $password->getID(); echo pht('Migrating VCS password %d...', $id)."\n"; $input_hash = $password->getPasswordHash(); $input_envelope = new PhutilOpaqueEnvelope($input_hash); $storage_hash = $best_hasher->getPasswordHashForStorage($input_envelope); queryfx( $conn_w, 'UPDATE %T SET passwordHash = %s WHERE id = %d', $table->getTableName(), $storage_hash->openEnvelope(), $id); } echo pht('Done.')."\n";