chamilo/chamilo-lms

View on GitHub
src/CoreBundle/Migrations/Schema/V200/Version20191206150000.php

Summary

Maintainability
A
0 mins
Test Coverage
<?php

declare(strict_types=1);

/* For licensing terms, see /license.txt */

namespace Chamilo\CoreBundle\Migrations\Schema\V200;

use Chamilo\CoreBundle\Migrations\AbstractMigrationChamilo;
use Doctrine\DBAL\Schema\Schema;

class Version20191206150000 extends AbstractMigrationChamilo
{
    public function getDescription(): string
    {
        return 'Extra field changes';
    }

    public function up(Schema $schema): void
    {
        $table = $schema->getTable('extra_field');
        if (false === $table->hasColumn('helper_text')) {
            $this->addSql('ALTER TABLE extra_field ADD helper_text text DEFAULT NULL AFTER display_text');
        }
        $this->addSql('ALTER TABLE extra_field_values CHANGE field_value field_value LONGTEXT DEFAULT NULL;');
        if (false === $table->hasColumn('description')) {
            $this->addSql('ALTER TABLE extra_field ADD description LONGTEXT DEFAULT NULL');
        }

        $table = $schema->getTable('extra_field_values');

        $this->addSql("UPDATE extra_field_values SET created_at = NOW() WHERE CAST(created_at AS CHAR(20)) = '0000-00-00 00:00:00'");
        $this->addSql("UPDATE extra_field_values SET updated_at = NOW() WHERE CAST(updated_at AS CHAR(20)) = '0000-00-00 00:00:00'");
        $this->addSql('ALTER TABLE extra_field_values MODIFY COLUMN field_value LONGTEXT NULL');

        if (!$table->hasIndex('idx_efv_item')) {
            $this->addSql('CREATE INDEX idx_efv_item ON extra_field_values (item_id)');
        }

        if (!$table->hasColumn('asset_id')) {
            $this->addSql("ALTER TABLE extra_field_values ADD asset_id BINARY(16) DEFAULT NULL COMMENT '(DC2Type:uuid)'");
        }

        if (!$table->hasForeignKey('FK_171DF9245DA1941')) {
            $this->addSql('ALTER TABLE extra_field_values ADD CONSTRAINT FK_171DF9245DA1941 FOREIGN KEY (asset_id) REFERENCES asset (id) ON DELETE CASCADE');
        }

        if (!$table->hasIndex('IDX_171DF9245DA1941')) {
            $this->addSql('CREATE INDEX IDX_171DF9245DA1941 ON extra_field_values (asset_id)');
        }

        $table = $schema->getTable('extra_field_option_rel_field_option');
        if (!$table->hasForeignKey('FK_8E04DF6B42C79BE5')) {
            $this->addSql('ALTER TABLE extra_field_option_rel_field_option ADD CONSTRAINT FK_8E04DF6B42C79BE5 FOREIGN KEY (field_option_id) REFERENCES extra_field_options (id);');
            $this->addSql('CREATE INDEX IDX_8E04DF6B42C79BE5 ON extra_field_option_rel_field_option (field_option_id)');
        }
        if (!$table->hasForeignKey('FK_8E04DF6BCFAFCECC')) {
            $this->addSql('ALTER TABLE extra_field_option_rel_field_option ADD CONSTRAINT FK_8E04DF6BCFAFCECC FOREIGN KEY (related_field_option_id) REFERENCES extra_field_options (id);');
            $this->addSql('CREATE INDEX IDX_8E04DF6BCFAFCECC ON extra_field_option_rel_field_option (related_field_option_id);');
        }
        if (!$table->hasForeignKey('FK_8E04DF6B443707B0')) {
            $this->addSql('ALTER TABLE extra_field_option_rel_field_option ADD CONSTRAINT FK_8E04DF6B443707B0 FOREIGN KEY (field_id) REFERENCES extra_field (id);');
            $this->addSql('CREATE INDEX IDX_8E04DF6B443707B0 ON extra_field_option_rel_field_option (field_id);');
        }

        $table = $schema->getTable('extra_field_rel_tag');

        $this->addSql('ALTER TABLE extra_field_rel_tag CHANGE field_id field_id INT DEFAULT NULL');
        $this->addSql('ALTER TABLE extra_field_rel_tag CHANGE tag_id tag_id INT DEFAULT NULL');

        if (!$table->hasForeignKey('FK_F8817295443707B0')) {
            $this->addSql('ALTER TABLE extra_field_rel_tag ADD CONSTRAINT FK_F8817295443707B0 FOREIGN KEY (field_id) REFERENCES extra_field (id) ON DELETE CASCADE');
        }

        $this->addSql('DELETE FROM extra_field_rel_tag WHERE tag_id NOT IN (SELECT id FROM tag)');
        if (!$table->hasForeignKey('FK_F8817295BAD26311')) {
            $this->addSql(
                'ALTER TABLE extra_field_rel_tag ADD CONSTRAINT FK_F8817295BAD26311 FOREIGN KEY (tag_id) REFERENCES tag (id) ON DELETE CASCADE'
            );
        }

        $table = $schema->getTable('tag');
        $this->addSql('ALTER TABLE tag CHANGE field_id field_id INT DEFAULT NULL');
        if (!$table->hasForeignKey('FK_389B783443707B0')) {
            $this->addSql(
                'ALTER TABLE tag ADD CONSTRAINT FK_389B783443707B0 FOREIGN KEY (field_id) REFERENCES extra_field (id) ON DELETE CASCADE'
            );
            $this->addSql('CREATE INDEX IDX_389B783443707B0 ON tag (field_id)');
        }
    }
}