TaoLer/vendor/topthink/think-migration/phinx/Migration/AbstractMigration.php
2024-04-01 10:04:16 +08:00

339 lines
6.9 KiB
PHP

<?php
/**
* MIT License
* For full license information, please view the LICENSE file that was distributed with this source code.
*/
namespace Phinx\Migration;
use Cake\Database\Query;
use Phinx\Db\Adapter\AdapterInterface;
use Phinx\Db\Table;
use RuntimeException;
use think\console\Input as InputInterface;
use think\console\Output as OutputInterface;
/**
* Abstract Migration Class.
*
* It is expected that the migrations you write extend from this class.
*
* This abstract class proxies the various database methods to your specified
* adapter.
*
* @author Rob Morgan <robbym@gmail.com>
*/
abstract class AbstractMigration implements MigrationInterface
{
/**
* @var string
*/
protected $environment;
/**
* @var int
*/
protected $version;
/**
* @var \Phinx\Db\Adapter\AdapterInterface|null
*/
protected $adapter;
/**
* @var \think\console\Output|null
*/
protected $output;
/**
* @var \think\console\Input|null
*/
protected $input;
/**
* Whether this migration is being applied or reverted
*
* @var bool
*/
protected $isMigratingUp = true;
/**
* List of all the table objects created by this migration
*
* @var array<\Phinx\Db\Table>
*/
protected $tables = [];
/**
* @param string $environment Environment Detected
* @param int $version Migration Version
* @param \think\console\Input|null $input Input
* @param \think\console\Output|null $output Output
*/
final public function __construct(string $environment, int $version, ?InputInterface $input = null, ?OutputInterface $output = null)
{
$this->environment = $environment;
$this->version = $version;
if ($input !== null) {
$this->setInput($input);
}
if ($output !== null) {
$this->setOutput($output);
}
}
/**
* @inheritDoc
*/
public function setAdapter(AdapterInterface $adapter): MigrationInterface
{
$this->adapter = $adapter;
return $this;
}
/**
* @inheritDoc
*/
public function getAdapter(): ?AdapterInterface
{
return $this->adapter;
}
/**
* @inheritDoc
*/
public function setInput(InputInterface $input): MigrationInterface
{
$this->input = $input;
return $this;
}
/**
* @inheritDoc
*/
public function getInput(): ?InputInterface
{
return $this->input;
}
/**
* @inheritDoc
*/
public function setOutput(OutputInterface $output): MigrationInterface
{
$this->output = $output;
return $this;
}
/**
* @inheritDoc
*/
public function getOutput(): ?OutputInterface
{
return $this->output;
}
/**
* @inheritDoc
*/
public function getName(): string
{
return static::class;
}
/**
* @inheritDoc
*/
public function getEnvironment(): string
{
return $this->environment;
}
/**
* @inheritDoc
*/
public function setVersion($version): MigrationInterface
{
$this->version = $version;
return $this;
}
/**
* @inheritDoc
*/
public function getVersion(): int
{
return $this->version;
}
/**
* @inheritDoc
*/
public function setMigratingUp(bool $isMigratingUp): MigrationInterface
{
$this->isMigratingUp = $isMigratingUp;
return $this;
}
/**
* @inheritDoc
*/
public function isMigratingUp(): bool
{
return $this->isMigratingUp;
}
/**
* @inheritDoc
*/
public function execute(string $sql, array $params = []): int
{
return $this->getAdapter()->execute($sql, $params);
}
/**
* @inheritDoc
*/
public function query(string $sql, array $params = [])
{
return $this->getAdapter()->query($sql, $params);
}
/**
* @inheritDoc
*/
public function getQueryBuilder(): Query
{
return $this->getAdapter()->getQueryBuilder();
}
/**
* @inheritDoc
*/
public function fetchRow(string $sql)
{
return $this->getAdapter()->fetchRow($sql);
}
/**
* @inheritDoc
*/
public function fetchAll(string $sql): array
{
return $this->getAdapter()->fetchAll($sql);
}
/**
* @inheritDoc
*/
public function createDatabase(string $name, array $options): void
{
$this->getAdapter()->createDatabase($name, $options);
}
/**
* @inheritDoc
*/
public function dropDatabase(string $name): void
{
$this->getAdapter()->dropDatabase($name);
}
/**
* @inheritDoc
*/
public function createSchema(string $name): void
{
$this->getAdapter()->createSchema($name);
}
/**
* @inheritDoc
*/
public function dropSchema(string $name): void
{
$this->getAdapter()->dropSchema($name);
}
/**
* @inheritDoc
*/
public function hasTable(string $tableName): bool
{
return $this->getAdapter()->hasTable($tableName);
}
/**
* @inheritDoc
*/
public function table(string $tableName, array $options = []): Table
{
$table = new Table($tableName, $options, $this->getAdapter());
$this->tables[] = $table;
return $table;
}
/**
* Perform checks on the migration, print a warning
* if there are potential problems.
*
* Right now, the only check is if there is both a `change()` and
* an `up()` or a `down()` method.
*
* @return void
*/
public function preFlightCheck(): void
{
if (method_exists($this, MigrationInterface::CHANGE)) {
if (
method_exists($this, MigrationInterface::UP) ||
method_exists($this, MigrationInterface::DOWN)
) {
$this->output->writeln(sprintf(
'<comment>warning</comment> Migration contains both change() and up()/down() methods. <options=bold>Ignoring up() and down()</>.'
));
}
}
}
/**
* Perform checks on the migration after completion
*
* Right now, the only check is whether all changes were committed
*
* @throws \RuntimeException
* @return void
*/
public function postFlightCheck(): void
{
foreach ($this->tables as $table) {
if ($table->hasPendingActions()) {
throw new RuntimeException('Migration has pending actions after execution!');
}
}
}
/**
* Checks to see if the migration should be executed.
*
* Returns true by default.
*
* You can use this to prevent a migration from executing.
*
* @return bool
*/
public function shouldExecute(): bool
{
return true;
}
}