<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
final class Version20250113162433 extends AbstractMigration
{
public function getDescription(): string
{
return 'Create dict_entity_type table';
}
public function up(Schema $schema): void
{
$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))');
$this->addSql('CREATE UNIQUE INDEX UNIQ_5E0CFEAA5E237E06 ON dict_entity_type (name)');
$this->addSql('CREATE UNIQUE INDEX UNIQ_5E0CFEAA77153098 ON dict_entity_type (code)');
$this->addSql('CREATE INDEX IDX_5E0CFEAADE12AB56 ON dict_entity_type (created_by)');
$this->addSql('CREATE INDEX IDX_5E0CFEAA16FE72E1 ON dict_entity_type (updated_by)');
$this->addSql('COMMENT ON COLUMN dict_entity_type.id IS \'(DC2Type:uuid)\'');
$this->addSql('COMMENT ON COLUMN dict_entity_type.created_by IS \'(DC2Type:uuid)\'');
$this->addSql('COMMENT ON COLUMN dict_entity_type.updated_by IS \'(DC2Type:uuid)\'');
$this->addSql('ALTER TABLE dict_entity_type ADD CONSTRAINT FK_5E0CFEAADE12AB56 FOREIGN KEY (created_by) REFERENCES "user" (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('ALTER TABLE dict_entity_type ADD CONSTRAINT FK_5E0CFEAA16FE72E1 FOREIGN KEY (updated_by) REFERENCES "user" (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('ALTER TABLE applicant ADD entity_type_id UUID DEFAULT NULL');
$this->addSql('COMMENT ON COLUMN applicant.entity_type_id IS \'(DC2Type:uuid)\'');
$this->addSql('ALTER TABLE applicant ADD CONSTRAINT FK_CAAD10195681BEB0 FOREIGN KEY (entity_type_id) REFERENCES dict_entity_type (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('CREATE INDEX IDX_CAAD10195681BEB0 ON applicant (entity_type_id)');
$this->addSql('ALTER TABLE contractor DROP CONSTRAINT fk_437bd2efb309296a');
$this->addSql('DROP INDEX idx_437bd2efb309296a');
$this->addSql('ALTER TABLE contractor RENAME COLUMN applicant_type_id TO entity_type_id');
$this->addSql('ALTER TABLE contractor ADD CONSTRAINT FK_437BD2EF5681BEB0 FOREIGN KEY (entity_type_id) REFERENCES dict_entity_type (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('CREATE INDEX IDX_437BD2EF5681BEB0 ON contractor (entity_type_id)');
$this->addSql("INSERT INTO dict_entity_type (id, name, code) SELECT id, name, code FROM dict_applicant_type");
$this->addSql("UPDATE applicant SET entity_type_id = applicant_type_id WHERE applicant_type_id IS NOT NULL");
}
public function down(Schema $schema): void
{
$this->addSql('ALTER TABLE applicant DROP CONSTRAINT FK_CAAD10195681BEB0');
$this->addSql('ALTER TABLE contractor DROP CONSTRAINT FK_437BD2EF5681BEB0');
$this->addSql('ALTER TABLE dict_entity_type DROP CONSTRAINT FK_5E0CFEAADE12AB56');
$this->addSql('ALTER TABLE dict_entity_type DROP CONSTRAINT FK_5E0CFEAA16FE72E1');
$this->addSql('DROP TABLE dict_entity_type');
$this->addSql('DROP INDEX IDX_CAAD10195681BEB0');
$this->addSql('ALTER TABLE applicant DROP entity_type_id');
$this->addSql('DROP INDEX IDX_437BD2EF5681BEB0');
$this->addSql('ALTER TABLE contractor RENAME COLUMN entity_type_id TO applicant_type_id');
$this->addSql('ALTER TABLE contractor ADD CONSTRAINT fk_437bd2efb309296a FOREIGN KEY (applicant_type_id) REFERENCES dict_applicant_type (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('CREATE INDEX idx_437bd2efb309296a ON contractor (applicant_type_id)');
}
}