006a191544
* Move the database handling to Doctrine DBAL * Move Migrations to Doctrine Migrations * Rename migrations for Doctrine Migrations Uses * Fix Migrations * Change config parameters, introduce db name, host and port parameters and get rid of database url * Change install form for this * Add a CLI command to make migrations * Add config.test.php to be used with APP_ENV=test for testing Signed-off-by: Thomas Citharel <tcit@tcit.fr> CS Signed-off-by: Thomas Citharel <tcit@tcit.fr> Add sqlite to CI and execute migration in test env Signed-off-by: Thomas Citharel <tcit@tcit.fr> Typo Signed-off-by: Thomas Citharel <tcit@tcit.fr> SQLite is already inside the image... Signed-off-by: Thomas Citharel <tcit@tcit.fr> Rebase two new migrations Signed-off-by: Thomas Citharel <tcit@tcit.fr> Move from trait to abstract class and remove legacy migration table after checks Signed-off-by: Thomas Citharel <tcit@tcit.fr> CS Signed-off-by: Thomas Citharel <tcit@tcit.fr> Move doctrine command path inside CI Signed-off-by: Thomas Citharel <tcit@tcit.fr> Move abstract migration class to correct namespace and remove unused command Signed-off-by: Thomas Citharel <tcit@tcit.fr> CS Signed-off-by: Thomas Citharel <tcit@tcit.fr> Check for legacy migration table existence Signed-off-by: Thomas Citharel <tcit@tcit.fr> Check if legacy migration table exists before deleting it Signed-off-by: Thomas Citharel <tcit@tcit.fr> Add messages for skipped migrations and fix an issue with MySQL ERR_NO_DATE Migration Signed-off-by: Thomas Citharel <tcit@tcit.fr>
59 lines
2.0 KiB
PHP
Executable File
59 lines
2.0 KiB
PHP
Executable File
#!/usr/bin/env php
|
|
<?php
|
|
|
|
use Doctrine\DBAL\Migrations\Configuration\Configuration;
|
|
use Doctrine\DBAL\Tools\Console\Helper\ConnectionHelper;
|
|
use Framadate\Utils;
|
|
use Symfony\Component\Console\Application;
|
|
use Symfony\Component\Console\Helper\HelperSet;
|
|
use Symfony\Component\Console\Helper\QuestionHelper;
|
|
use Symfony\Component\Console\Input\ArgvInput;
|
|
use Symfony\Component\Console\Output\ConsoleOutput;
|
|
use Symfony\Component\Console\Style\SymfonyStyle;
|
|
|
|
try {
|
|
require_once __DIR__ . '/../app/inc/init.php';
|
|
|
|
$input = new ArgvInput();
|
|
$output = new ConsoleOutput();
|
|
$style = new SymfonyStyle($input, $output);
|
|
|
|
if ($connect === null) {
|
|
throw new \Exception("Undefined database connection\n");
|
|
}
|
|
|
|
// replace the ConsoleRunner::run() statement with:
|
|
$cli = new Application('Doctrine Command Line Interface', VERSION);
|
|
$cli->setCatchExceptions(true);
|
|
|
|
$helperSet = new HelperSet(
|
|
[
|
|
'db' => new ConnectionHelper($connect),
|
|
'question' => new QuestionHelper(),
|
|
]
|
|
);
|
|
|
|
$cli->setHelperSet($helperSet);
|
|
|
|
$migrateCommand = new \Doctrine\DBAL\Migrations\Tools\Console\Command\MigrateCommand();
|
|
$statusCommand = new \Doctrine\DBAL\Migrations\Tools\Console\Command\StatusCommand();
|
|
|
|
$migrationsDirectory = __DIR__ . '/../app/classes/Framadate/Migrations';
|
|
|
|
$configuration = new Configuration($connect);
|
|
$configuration->setMigrationsTableName(Utils::table(MIGRATION_TABLE) . '_new');
|
|
$configuration->setMigrationsDirectory($migrationsDirectory);
|
|
$configuration->setMigrationsNamespace('DoctrineMigrations');
|
|
$configuration->registerMigrationsFromDirectory($migrationsDirectory);
|
|
$migrateCommand->setMigrationConfiguration($configuration);
|
|
$statusCommand->setMigrationConfiguration($configuration);
|
|
|
|
// Register All Doctrine Commands
|
|
$cli->addCommands([$migrateCommand, $statusCommand]);
|
|
|
|
// Runs console application
|
|
$cli->run($input, $output);
|
|
} catch (\Exception $e) {
|
|
$style->error($e->getMessage());
|
|
}
|