silverstripe-userforms/code/Task/UserFormsColumnCleanTask.php

74 lines
2.5 KiB
PHP
Raw Normal View History

<?php
namespace SilverStripe\UserForms\Task;
use SilverStripe\Dev\BuildTask;
use SilverStripe\PolyExecution\PolyOutput;
use SilverStripe\ORM\DataObject;
use SilverStripe\ORM\DB;
use SilverStripe\UserForms\Model\EditableFormField;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputInterface;
/**
* UserForms Column Clean Task
*
* Column clean up tasks for Userforms
*
* @package userforms
*/
class UserFormsColumnCleanTask extends BuildTask
2016-07-21 17:53:59 +12:00
{
protected static string $commandName = 'userforms-column-clean';
2016-07-21 17:53:59 +12:00
protected string $title = 'UserForms EditableFormField Column Clean task';
protected static string $description = 'Removes unused columns from EditableFormField for MySQL databases;';
2016-07-21 17:53:59 +12:00
protected $tables = [EditableFormField::class];
2016-07-21 17:53:59 +12:00
protected $keepColumns = ['ID'];
2016-07-21 17:53:59 +12:00
/**
* Publish the existing forms.
*/
protected function execute(InputInterface $input, PolyOutput $output): int
2016-07-21 17:53:59 +12:00
{
$schema = DataObject::getSchema();
2016-07-21 17:53:59 +12:00
foreach ($this->tables as $db) {
$table = $schema->tableName($db);
$columns = $schema->databaseFields($db);
$query = "SHOW COLUMNS FROM $table";
2016-07-21 17:53:59 +12:00
$liveColumns = DB::query($query)->column();
$query = "SHOW TABLES LIKE 'Backup_$table'";
2016-07-21 17:53:59 +12:00
$tableExists = DB::query($query)->value();
if ($tableExists != null) {
2024-10-22 16:48:00 +13:00
$output->writeln("Tasks run already on $table exiting");
return Command::SUCCESS;
2016-07-21 17:53:59 +12:00
}
$backedUp = false;
foreach ($liveColumns as $column) {
if (!$backedUp) {
2024-10-22 16:48:00 +13:00
$output->writeln("Backing up $table <br />");
$output->writeln("Creating Backup_$table <br />");
2016-07-21 17:53:59 +12:00
// backup table
$query = "CREATE TABLE Backup_$table LIKE $table";
2016-07-21 17:53:59 +12:00
DB::query($query);
2024-10-22 16:48:00 +13:00
$output->writeln("Populating Backup_$table <br />");
$query = "INSERT Backup_$table SELECT * FROM $table";
2016-07-21 17:53:59 +12:00
DB::query($query);
$backedUp = true;
2016-07-21 17:53:59 +12:00
}
2022-04-13 13:52:56 +12:00
if (!isset($columns[$column]) && !in_array($column, $this->keepColumns ?? [])) {
2024-10-22 16:48:00 +13:00
$output->writeln("Dropping $column from $table <br />");
$query = "ALTER TABLE $table DROP COLUMN $column";
2016-07-21 17:53:59 +12:00
DB::query($query);
}
}
}
return Command::SUCCESS;
2016-07-21 17:53:59 +12:00
}
}