migrations/Version20240706080141.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. /**
  7.  * Auto-generated Migration: Please modify to your needs!
  8.  */
  9. final class Version20240706080141 extends AbstractMigration
  10. {
  11.     public function getDescription(): string
  12.     {
  13.         return '';
  14.     }
  15.     public function up(Schema $schema): void
  16.     {
  17.         // this up() migration is auto-generated, please modify it to your needs
  18.         $this->addSql('CREATE TABLE applicant (id UUID NOT NULL, applicant_type_id UUID DEFAULT NULL, created_by UUID DEFAULT NULL, updated_by UUID DEFAULT NULL, first_name VARCHAR(255) NOT NULL, last_name VARCHAR(255) NOT NULL, name VARCHAR(255) NOT NULL, phone_number VARCHAR(255) NOT NULL, phone_number2 VARCHAR(255) NOT NULL, email VARCHAR(255) NOT NULL, postal_code VARCHAR(255) NOT NULL, post_office VARCHAR(255) NOT NULL, city VARCHAR(255) NOT NULL, street VARCHAR(255) NOT NULL, house_number VARCHAR(255) NOT NULL, apartment_number 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))');
  19.         $this->addSql('CREATE INDEX IDX_CAAD1019B309296A ON applicant (applicant_type_id)');
  20.         $this->addSql('CREATE INDEX IDX_CAAD1019DE12AB56 ON applicant (created_by)');
  21.         $this->addSql('CREATE INDEX IDX_CAAD101916FE72E1 ON applicant (updated_by)');
  22.         $this->addSql('COMMENT ON COLUMN applicant.id IS \'(DC2Type:uuid)\'');
  23.         $this->addSql('COMMENT ON COLUMN applicant.applicant_type_id IS \'(DC2Type:uuid)\'');
  24.         $this->addSql('COMMENT ON COLUMN applicant.created_by IS \'(DC2Type:uuid)\'');
  25.         $this->addSql('COMMENT ON COLUMN applicant.updated_by IS \'(DC2Type:uuid)\'');
  26.         $this->addSql('CREATE TABLE application_attachment (id UUID NOT NULL, attachment_id UUID DEFAULT NULL, application_id UUID DEFAULT NULL, PRIMARY KEY(id))');
  27.         $this->addSql('CREATE UNIQUE INDEX UNIQ_EDCE857464E68B ON application_attachment (attachment_id)');
  28.         $this->addSql('CREATE INDEX IDX_EDCE8573E030ACD ON application_attachment (application_id)');
  29.         $this->addSql('COMMENT ON COLUMN application_attachment.id IS \'(DC2Type:uuid)\'');
  30.         $this->addSql('COMMENT ON COLUMN application_attachment.attachment_id IS \'(DC2Type:uuid)\'');
  31.         $this->addSql('COMMENT ON COLUMN application_attachment.application_id IS \'(DC2Type:uuid)\'');
  32.         $this->addSql('CREATE TABLE dict_applicant_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))');
  33.         $this->addSql('CREATE UNIQUE INDEX UNIQ_6B0157D95E237E06 ON dict_applicant_type (name)');
  34.         $this->addSql('CREATE UNIQUE INDEX UNIQ_6B0157D977153098 ON dict_applicant_type (code)');
  35.         $this->addSql('CREATE INDEX IDX_6B0157D9DE12AB56 ON dict_applicant_type (created_by)');
  36.         $this->addSql('CREATE INDEX IDX_6B0157D916FE72E1 ON dict_applicant_type (updated_by)');
  37.         $this->addSql('COMMENT ON COLUMN dict_applicant_type.id IS \'(DC2Type:uuid)\'');
  38.         $this->addSql('COMMENT ON COLUMN dict_applicant_type.created_by IS \'(DC2Type:uuid)\'');
  39.         $this->addSql('COMMENT ON COLUMN dict_applicant_type.updated_by IS \'(DC2Type:uuid)\'');
  40.         $this->addSql('ALTER TABLE applicant ADD CONSTRAINT FK_CAAD1019B309296A FOREIGN KEY (applicant_type_id) REFERENCES dict_applicant_type (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  41.         $this->addSql('ALTER TABLE applicant ADD CONSTRAINT FK_CAAD1019DE12AB56 FOREIGN KEY (created_by) REFERENCES "user" (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  42.         $this->addSql('ALTER TABLE applicant ADD CONSTRAINT FK_CAAD101916FE72E1 FOREIGN KEY (updated_by) REFERENCES "user" (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  43.         $this->addSql('ALTER TABLE application_attachment ADD CONSTRAINT FK_EDCE857464E68B FOREIGN KEY (attachment_id) REFERENCES attachment (id) ON DELETE CASCADE NOT DEFERRABLE INITIALLY IMMEDIATE');
  44.         $this->addSql('ALTER TABLE application_attachment ADD CONSTRAINT FK_EDCE8573E030ACD FOREIGN KEY (application_id) REFERENCES application (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  45.         $this->addSql('ALTER TABLE dict_applicant_type ADD CONSTRAINT FK_6B0157D9DE12AB56 FOREIGN KEY (created_by) REFERENCES "user" (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  46.         $this->addSql('ALTER TABLE dict_applicant_type ADD CONSTRAINT FK_6B0157D916FE72E1 FOREIGN KEY (updated_by) REFERENCES "user" (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
  47.     }
  48.     public function down(Schema $schema): void
  49.     {
  50.         // this down() migration is auto-generated, please modify it to your needs
  51.         $this->addSql('CREATE SCHEMA public');
  52.         $this->addSql('ALTER TABLE applicant DROP CONSTRAINT FK_CAAD1019B309296A');
  53.         $this->addSql('ALTER TABLE applicant DROP CONSTRAINT FK_CAAD1019DE12AB56');
  54.         $this->addSql('ALTER TABLE applicant DROP CONSTRAINT FK_CAAD101916FE72E1');
  55.         $this->addSql('ALTER TABLE application_attachment DROP CONSTRAINT FK_EDCE857464E68B');
  56.         $this->addSql('ALTER TABLE application_attachment DROP CONSTRAINT FK_EDCE8573E030ACD');
  57.         $this->addSql('ALTER TABLE dict_applicant_type DROP CONSTRAINT FK_6B0157D9DE12AB56');
  58.         $this->addSql('ALTER TABLE dict_applicant_type DROP CONSTRAINT FK_6B0157D916FE72E1');
  59.         $this->addSql('DROP TABLE applicant');
  60.         $this->addSql('DROP TABLE application_attachment');
  61.         $this->addSql('DROP TABLE dict_applicant_type');
  62.     }
  63. }