migrations/Version20220217125121.php line 1

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace DoctrineMigrations;
  4. use Doctrine\DBAL\Schema\Schema;
  5. use Doctrine\Migrations\AbstractMigration;
  6. final class Version20220217125121 extends AbstractMigration
  7. {
  8.     public function getDescription(): string
  9.     {
  10.         return 'add is_fixed field in time_entry, add table te_validation';
  11.     }
  12.     public function up(Schema $schema): void
  13.     {
  14.         $this->addSql('ALTER TABLE time_entry ADD is_fixed BOOLEAN DEFAULT \'false\'');
  15.         $this->addSql('COMMENT ON COLUMN time_entry.is_fixed IS \'Change prohibition\'');
  16.         $this->addSql('UPDATE time_entry SET is_fixed = false');
  17.         $this->addSql('ALTER TABLE time_entry ALTER is_fixed SET NOT NULL');
  18.         $this->addSql('CREATE SEQUENCE te_validation_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
  19.         $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))');
  20.         $this->addSql('CREATE UNIQUE INDEX UNIQ_DBA851721EB30A8E ON te_validation (time_entry_id)');
  21.         $this->addSql('CREATE INDEX IDX_DBA851725561CCEE ON te_validation (hub_user_id)');
  22.         $this->addSql('COMMENT ON COLUMN te_validation.time_entry_id IS \'(DC2Type:uuid)\'');
  23.         $this->addSql('COMMENT ON COLUMN te_validation.hub_user_id IS \'(DC2Type:uuid)\'');
  24.         $this->addSql('COMMENT ON COLUMN te_validation.updated_at IS \'DateTime of create/update(DC2Type:datetime_immutable)\'');
  25.         $this->addSql('COMMENT ON COLUMN te_validation.is_approved IS \'Approved value\'');
  26.         $this->addSql('ALTER TABLE te_validation ADD CONSTRAINT FK_DBA851721EB30A8E FOREIGN KEY (time_entry_id) REFERENCES time_entry (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  27.         $this->addSql('ALTER TABLE te_validation ADD CONSTRAINT FK_DBA851725561CCEE FOREIGN KEY (hub_user_id) REFERENCES hub_user (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  28.     }
  29.     public function down(Schema $schema): void
  30.     {
  31.         $this->addSql('ALTER TABLE time_entry DROP is_fixed');
  32.         $this->addSql('ALTER TABLE time_entry DROP is_approved');
  33.         $this->addSql('DROP SEQUENCE te_validation_id_seq CASCADE');
  34.         $this->addSql('DROP TABLE te_validation');
  35.     }
  36. }