Spaces:
No application file
No application file
| declare(strict_types=1); | |
| namespace Mautic\Migrations; | |
| use Doctrine\DBAL\Schema\Schema; | |
| use Doctrine\Migrations\Exception\SkipMigration; | |
| use Mautic\CoreBundle\Doctrine\AbstractMauticMigration; | |
| final class Version20200415135706 extends AbstractMauticMigration | |
| { | |
| public function preUp(Schema $schema): void | |
| { | |
| if ($schema->getTable("{$this->prefix}form_fields")->hasColumn('mapped_object')) { | |
| throw new SkipMigration('Schema includes this migration'); | |
| } | |
| } | |
| public function up(Schema $schema): void | |
| { | |
| $this->addSql("ALTER TABLE {$this->prefix}form_fields | |
| ADD mapped_object VARCHAR(191) DEFAULT NULL, | |
| ADD mapped_field VARCHAR(191) DEFAULT NULL"); | |
| // All field that starts with company belongs to the company object. | |
| // Except the company field itself that belongs to the contact (lead) object. | |
| $this->addSql("UPDATE {$this->prefix}form_fields | |
| SET mapped_object = CASE | |
| WHEN lead_field LIKE 'company%' AND lead_field != 'company' THEN 'company' | |
| ELSE 'contact' | |
| END, mapped_field = lead_field | |
| WHERE lead_field IS NOT NULL"); | |
| } | |
| } | |