![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/mautic.corals.io/app/migrations/ |
<?php namespace Mautic\Migrations; use Doctrine\DBAL\Schema\Schema; use Doctrine\Migrations\Exception\SkipMigration; use Mautic\CoreBundle\Doctrine\AbstractMauticMigration; class Version20190410143658 extends AbstractMauticMigration { /** * @throws \Doctrine\DBAL\Schema\SchemaException */ public function preUp(Schema $schema): void { $newIndexName = $this->getNewIndexName(); $tableName = $this->getTableName(); $table = $schema->getTable($tableName); if (true === $table->hasIndex($newIndexName)) { throw new SkipMigration('Schema includes this migration'); } } /** * @throws \Doctrine\DBAL\Schema\SchemaException */ public function up(Schema $schema): void { $newIndexName = $this->getNewIndexName(); $tableName = $this->getTableName(); $oldIndexName = $this->getOldIndexName($tableName); $this->addSql("ALTER TABLE {$tableName} ADD INDEX {$newIndexName} (lead_id, channel, reason);"); if ($schema->getTable($tableName)->hasIndex($oldIndexName)) { $this->addSql("ALTER TABLE {$tableName} DROP INDEX {$oldIndexName};"); } } /** * @param string $tableName * * @return string */ private function getOldIndexName($tableName) { return $this->generatePropertyName($tableName, 'idx', ['lead_id']); } /** * @return string */ private function getNewIndexName() { return "{$this->prefix}leadid_reason_channel"; } /** * @return string */ private function getTableName() { return "{$this->prefix}lead_donotcontact"; } }