<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
final class Version20220217125121 extends AbstractMigration
{
public function getDescription(): string
{
return 'add is_fixed field in time_entry, add table te_validation';
}
public function up(Schema $schema): void
{
$this->addSql('ALTER TABLE time_entry ADD is_fixed BOOLEAN DEFAULT \'false\'');
$this->addSql('COMMENT ON COLUMN time_entry.is_fixed IS \'Change prohibition\'');
$this->addSql('UPDATE time_entry SET is_fixed = false');
$this->addSql('ALTER TABLE time_entry ALTER is_fixed SET NOT NULL');
$this->addSql('CREATE SEQUENCE te_validation_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
$this->addSql('CREATE TABLE te_validation (id INT NOT NULL, time_entry_id UUID NOT NULL, hub_user_id UUID NOT NULL, updated_at TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, is_approved BOOLEAN DEFAULT \'true\' NOT NULL, PRIMARY KEY(id))');
$this->addSql('CREATE UNIQUE INDEX UNIQ_DBA851721EB30A8E ON te_validation (time_entry_id)');
$this->addSql('CREATE INDEX IDX_DBA851725561CCEE ON te_validation (hub_user_id)');
$this->addSql('COMMENT ON COLUMN te_validation.time_entry_id IS \'(DC2Type:uuid)\'');
$this->addSql('COMMENT ON COLUMN te_validation.hub_user_id IS \'(DC2Type:uuid)\'');
$this->addSql('COMMENT ON COLUMN te_validation.updated_at IS \'DateTime of create/update(DC2Type:datetime_immutable)\'');
$this->addSql('COMMENT ON COLUMN te_validation.is_approved IS \'Approved value\'');
$this->addSql('ALTER TABLE te_validation ADD CONSTRAINT FK_DBA851721EB30A8E FOREIGN KEY (time_entry_id) REFERENCES time_entry (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('ALTER TABLE te_validation ADD CONSTRAINT FK_DBA851725561CCEE FOREIGN KEY (hub_user_id) REFERENCES hub_user (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
}
public function down(Schema $schema): void
{
$this->addSql('ALTER TABLE time_entry DROP is_fixed');
$this->addSql('ALTER TABLE time_entry DROP is_approved');
$this->addSql('DROP SEQUENCE te_validation_id_seq CASCADE');
$this->addSql('DROP TABLE te_validation');
}
}