migrations/Version20250113162433.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 Version20250113162433 extends AbstractMigration
  7. {
  8.     public function getDescription(): string
  9.     {
  10.         return 'Create dict_entity_type table';
  11.     }
  12.     public function up(Schema $schema): void
  13.     {
  14.         $this->addSql('CREATE TABLE dict_entity_type (id UUID NOT NULL, created_by UUID DEFAULT NULL, updated_by UUID DEFAULT NULL, name VARCHAR(255) NOT NULL, code VARCHAR(255) NOT NULL, created_at TIMESTAMP(0) WITHOUT TIME ZONE DEFAULT NULL, updated_at TIMESTAMP(0) WITHOUT TIME ZONE DEFAULT NULL, deleted_at TIMESTAMP(0) WITHOUT TIME ZONE DEFAULT NULL, PRIMARY KEY(id))');
  15.         $this->addSql('CREATE UNIQUE INDEX UNIQ_5E0CFEAA5E237E06 ON dict_entity_type (name)');
  16.         $this->addSql('CREATE UNIQUE INDEX UNIQ_5E0CFEAA77153098 ON dict_entity_type (code)');
  17.         $this->addSql('CREATE INDEX IDX_5E0CFEAADE12AB56 ON dict_entity_type (created_by)');
  18.         $this->addSql('CREATE INDEX IDX_5E0CFEAA16FE72E1 ON dict_entity_type (updated_by)');
  19.         $this->addSql('COMMENT ON COLUMN dict_entity_type.id IS \'(DC2Type:uuid)\'');
  20.         $this->addSql('COMMENT ON COLUMN dict_entity_type.created_by IS \'(DC2Type:uuid)\'');
  21.         $this->addSql('COMMENT ON COLUMN dict_entity_type.updated_by IS \'(DC2Type:uuid)\'');
  22.         $this->addSql('ALTER TABLE dict_entity_type ADD CONSTRAINT FK_5E0CFEAADE12AB56 FOREIGN KEY (created_by) REFERENCES "user" (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  23.         $this->addSql('ALTER TABLE dict_entity_type ADD CONSTRAINT FK_5E0CFEAA16FE72E1 FOREIGN KEY (updated_by) REFERENCES "user" (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  24.         $this->addSql('ALTER TABLE applicant ADD entity_type_id UUID DEFAULT NULL');
  25.         $this->addSql('COMMENT ON COLUMN applicant.entity_type_id IS \'(DC2Type:uuid)\'');
  26.         $this->addSql('ALTER TABLE applicant ADD CONSTRAINT FK_CAAD10195681BEB0 FOREIGN KEY (entity_type_id) REFERENCES dict_entity_type (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  27.         $this->addSql('CREATE INDEX IDX_CAAD10195681BEB0 ON applicant (entity_type_id)');
  28.         $this->addSql('ALTER TABLE contractor DROP CONSTRAINT fk_437bd2efb309296a');
  29.         $this->addSql('DROP INDEX idx_437bd2efb309296a');
  30.         $this->addSql('ALTER TABLE contractor RENAME COLUMN applicant_type_id TO entity_type_id');
  31.         $this->addSql('ALTER TABLE contractor ADD CONSTRAINT FK_437BD2EF5681BEB0 FOREIGN KEY (entity_type_id) REFERENCES dict_entity_type (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  32.         $this->addSql('CREATE INDEX IDX_437BD2EF5681BEB0 ON contractor (entity_type_id)');
  33.         $this->addSql("INSERT INTO dict_entity_type (id, name, code) SELECT id, name, code FROM dict_applicant_type");
  34.         $this->addSql("UPDATE applicant SET entity_type_id = applicant_type_id WHERE applicant_type_id IS NOT NULL");
  35.     }
  36.     public function down(Schema $schema): void
  37.     {
  38.         $this->addSql('ALTER TABLE applicant DROP CONSTRAINT FK_CAAD10195681BEB0');
  39.         $this->addSql('ALTER TABLE contractor DROP CONSTRAINT FK_437BD2EF5681BEB0');
  40.         $this->addSql('ALTER TABLE dict_entity_type DROP CONSTRAINT FK_5E0CFEAADE12AB56');
  41.         $this->addSql('ALTER TABLE dict_entity_type DROP CONSTRAINT FK_5E0CFEAA16FE72E1');
  42.         $this->addSql('DROP TABLE dict_entity_type');
  43.         $this->addSql('DROP INDEX IDX_CAAD10195681BEB0');
  44.         $this->addSql('ALTER TABLE applicant DROP entity_type_id');
  45.         $this->addSql('DROP INDEX IDX_437BD2EF5681BEB0');
  46.         $this->addSql('ALTER TABLE contractor RENAME COLUMN entity_type_id TO applicant_type_id');
  47.         $this->addSql('ALTER TABLE contractor ADD CONSTRAINT fk_437bd2efb309296a FOREIGN KEY (applicant_type_id) REFERENCES dict_applicant_type (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  48.         $this->addSql('CREATE INDEX idx_437bd2efb309296a ON contractor (applicant_type_id)');
  49.     }
  50. }