<?php
declare(strict_types=1);
namespace DoctrineMigrations;
use Doctrine\DBAL\Schema\Schema;
use Doctrine\Migrations\AbstractMigration;
final class Version20221205105601 extends AbstractMigration
{
public function getDescription(): string
{
return 'Add new field is_preoccupation to contact and create new table proxy_contact';
}
public function up(Schema $schema): void
{
$this->addSql('CREATE SEQUENCE proxy_contact_id_seq INCREMENT BY 1 MINVALUE 1 START 1');
$this->addSql('CREATE TABLE proxy_contact (id INT NOT NULL, first_name VARCHAR(255) NOT NULL, last_name VARCHAR(255) NOT NULL, phone VARCHAR(255) NOT NULL, email VARCHAR(255) DEFAULT NULL, PRIMARY KEY(id))');
$this->addSql('ALTER TABLE contact ADD proxy_contact_id INT DEFAULT NULL');
$this->addSql('ALTER TABLE contact ADD CONSTRAINT FK_4C62E638F137D8FC FOREIGN KEY (proxy_contact_id) REFERENCES proxy_contact (id) NOT DEFERRABLE INITIALLY IMMEDIATE');
$this->addSql('CREATE UNIQUE INDEX UNIQ_4C62E638F137D8FC ON contact (proxy_contact_id)');
$this->addSql('ALTER TABLE contact ADD is_preoccupation BOOLEAN DEFAULT NULL');
}
public function down(Schema $schema): void
{
$this->addSql('ALTER TABLE contact DROP CONSTRAINT FK_4C62E638F137D8FC');
$this->addSql('DROP SEQUENCE proxy_contact_id_seq CASCADE');
$this->addSql('DROP TABLE proxy_contact');
$this->addSql('DROP INDEX UNIQ_4C62E638F137D8FC');
$this->addSql('ALTER TABLE contact DROP proxy_contact_id');
$this->addSql('ALTER TABLE contact DROP is_preoccupation');
}
}