Passed
Pull Request — master (#5625)
by Angel Fernando Quiroz
13:00 queued 05:41
created

Version20240702222600::up()   B

Complexity

Conditions 7
Paths 64

Size

Total Lines 27
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Importance

Changes 2
Bugs 1 Features 0
Metric Value
cc 7
eloc 14
c 2
b 1
f 0
nc 64
nop 1
dl 0
loc 27
rs 8.8333
1
<?php
2
3
/* For licensing terms, see /license.txt */
4
5
declare(strict_types=1);
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 Version20240702222600 extends AbstractMigrationChamilo
13
{
14
    public function getDescription(): string
15
    {
16
        return 'Migration resource_node --* resource_file (during development)';
17
    }
18
19
    public function up(Schema $schema): void
20
    {
21
        $tblResourceFile = $schema->getTable('resource_file');
22
        $tblResourceNode = $schema->getTable('resource_node');
23
24
        if (!$tblResourceFile->hasColumn('resource_node_id')) {
25
            $this->addSql('ALTER TABLE resource_file ADD resource_node_id INT DEFAULT NULL');
26
        }
27
28
        if (!$tblResourceFile->hasForeignKey('FK_83BF96AA1BAD783F')) {
29
            $this->addSql('ALTER TABLE resource_file ADD CONSTRAINT FK_83BF96AA1BAD783F FOREIGN KEY (resource_node_id) REFERENCES resource_node (id)');
30
        }
31
32
        if (!$tblResourceFile->hasIndex('IDX_83BF96AA1BAD783F')) {
33
            $this->addSql('CREATE INDEX IDX_83BF96AA1BAD783F ON resource_file (resource_node_id)');
34
        }
35
36
        if ($tblResourceNode->hasForeignKey('FK_8A5F48FFCE6B9E84')) {
37
            $this->addSql('ALTER TABLE resource_node DROP FOREIGN KEY FK_8A5F48FFCE6B9E84');
38
        }
39
40
        if ($tblResourceNode->hasIndex('UNIQ_8A5F48FFCE6B9E84')) {
41
            $this->addSql('DROP INDEX UNIQ_8A5F48FFCE6B9E84 ON resource_node');
42
        }
43
44
        if ($tblResourceNode->hasColumn('resource_file_id')) {
45
            $this->addSql('ALTER TABLE resource_node DROP resource_file_id');
46
        }
47
    }
48
}
49