Passed
Pull Request — master (#6457)
by
unknown
07:53
created

Version20250709182000::down()   A

Complexity

Conditions 3
Paths 4

Size

Total Lines 22
Code Lines 9

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 3
eloc 9
c 1
b 0
f 0
nc 4
nop 1
dl 0
loc 22
rs 9.9666
1
<?php
2
3
declare(strict_types=1);
4
5
/* For licensing terms, see /license.txt */
6
7
namespace Chamilo\CoreBundle\Migrations\Schema\V200;
8
9
use Chamilo\CoreBundle\Migrations\AbstractMigrationChamilo;
10
use Doctrine\DBAL\Schema\Schema;
11
12
final class Version20250709182000 extends AbstractMigrationChamilo
13
{
14
    public function getDescription(): string
15
    {
16
        return 'Renames column name to variable in settings_value_template table.';
17
    }
18
19
    public function up(Schema $schema): void
20
    {
21
        $schemaManager = $this->connection->createSchemaManager();
22
23
        // Check column exists
24
        $columns = $schemaManager->listTableColumns('settings_value_template');
25
26
        if (isset($columns['name'])) {
27
            $this->addSql("
28
                ALTER TABLE settings_value_template
29
                CHANGE COLUMN name variable VARCHAR(190) NOT NULL;
30
            ");
31
            $this->write("Renamed column name → variable in settings_value_template.");
32
        }
33
34
        // Drop old index and recreate with new name
35
        $indexes = $schemaManager->listTableIndexes('settings_value_template');
36
        if (isset($indexes['UNIQ_settings_value_template_name'])) {
37
            $this->addSql("
38
                ALTER TABLE settings_value_template
39
                DROP INDEX UNIQ_settings_value_template_name,
40
                ADD UNIQUE INDEX UNIQ_settings_value_template_variable (variable);
41
            ");
42
            $this->write("Recreated unique index for variable column.");
43
        }
44
    }
45
46
    public function down(Schema $schema): void
47
    {
48
        $schemaManager = $this->connection->createSchemaManager();
49
50
        $columns = $schemaManager->listTableColumns('settings_value_template');
51
52
        if (isset($columns['variable'])) {
53
            $this->addSql("
54
                ALTER TABLE settings_value_template
55
                CHANGE COLUMN variable name VARCHAR(190) NOT NULL;
56
            ");
57
            $this->write("Renamed column variable → name in settings_value_template.");
58
        }
59
60
        $indexes = $schemaManager->listTableIndexes('settings_value_template');
61
        if (isset($indexes['UNIQ_settings_value_template_variable'])) {
62
            $this->addSql("
63
                ALTER TABLE settings_value_template
64
                DROP INDEX UNIQ_settings_value_template_variable,
65
                ADD UNIQUE INDEX UNIQ_settings_value_template_name (name);
66
            ");
67
            $this->write("Recreated unique index for name column.");
68
        }
69
    }
70
}
71