41 lines
1.5 KiB
PHP
41 lines
1.5 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace DoctrineMigrations;
|
|
|
|
use Doctrine\DBAL\Schema\Schema;
|
|
use Doctrine\Migrations\AbstractMigration;
|
|
|
|
/**
|
|
* ERP-172 — adresse UNIQUE par transporteur (decision metier : un transporteur a
|
|
* au plus une adresse). Bascule la relation carrier_address.carrier_id en OneToOne :
|
|
* remplace l'index simple idx_carrier_address_carrier par une contrainte d'unicite
|
|
* uniq_carrier_address_carrier. La garde applicative (CarrierAddressProcessor) renvoie
|
|
* un 409 explicite avant d'atteindre cette contrainte.
|
|
*
|
|
* Placee au namespace racine DoctrineMigrations (et non en modulaire Transport) :
|
|
* elle ALTERE une table creee par une migration racine (Version20260615150000) ;
|
|
* le tri par version au sein du meme namespace garantit qu'elle joue APRES l'init
|
|
* (cf. CLAUDE.md regle 11 — le tri cross-namespace casserait l'ordre sur base vide).
|
|
*/
|
|
final class Version20260617140000 extends AbstractMigration
|
|
{
|
|
public function getDescription(): string
|
|
{
|
|
return 'ERP-172 : adresse unique par transporteur — index unique sur carrier_address.carrier_id (OneToOne).';
|
|
}
|
|
|
|
public function up(Schema $schema): void
|
|
{
|
|
$this->addSql('DROP INDEX idx_carrier_address_carrier');
|
|
$this->addSql('CREATE UNIQUE INDEX uniq_carrier_address_carrier ON carrier_address (carrier_id)');
|
|
}
|
|
|
|
public function down(Schema $schema): void
|
|
{
|
|
$this->addSql('DROP INDEX uniq_carrier_address_carrier');
|
|
$this->addSql('CREATE INDEX idx_carrier_address_carrier ON carrier_address (carrier_id)');
|
|
}
|
|
}
|