Failed Conditions
Pull Request — master (#969)
by
unknown
09:23
created

MigrationRepository   A

Complexity

Total Complexity 15

Size/Duplication

Total Lines 127
Duplicated Lines 0 %

Test Coverage

Coverage 97.92%

Importance

Changes 2
Bugs 0 Features 0
Metric Value
eloc 42
c 2
b 0
f 0
dl 0
loc 127
ccs 47
cts 48
cp 0.9792
rs 10
wmc 15

9 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 11 1
A registerMigrationInstance() 0 12 2
A getMigrations() 0 5 1
A ensureMigrationClassExists() 0 4 2
A loadMigrationsFromDirectories() 0 16 3
A getMigration() 0 9 2
A hasMigration() 0 5 1
A registerMigration() 0 8 1
A registerMigrations() 0 9 2
1
<?php
2
3
declare(strict_types=1);
4
5
namespace Doctrine\Migrations;
6
7
use Doctrine\Migrations\Exception\DuplicateMigrationVersion;
8
use Doctrine\Migrations\Exception\MigrationClassNotFound;
9
use Doctrine\Migrations\Exception\MigrationException;
10
use Doctrine\Migrations\Finder\MigrationFinder;
11
use Doctrine\Migrations\Metadata\AvailableMigration;
12
use Doctrine\Migrations\Metadata\AvailableMigrationsSet;
13
use Doctrine\Migrations\Version\MigrationFactory;
14
use Doctrine\Migrations\Version\Version;
15
use function class_exists;
16
17
/**
18
 * The MigrationRepository class is responsible for retrieving migrations, determining what the current migration
19
 * version, etc.
20
 *
21
 * @internal
22
 */
23
class MigrationRepository
24
{
25
    /** @var bool */
26
    private $migrationsLoaded = false;
27
28
    /** @var array<string, string> */
29
    private $migrationDirectories;
30
31
    /** @var MigrationFinder */
32
    private $migrationFinder;
33
34
    /** @var MigrationFactory */
35
    private $versionFactory;
36
37
    /** @var AvailableMigration[] */
38
    private $migrations = [];
39
40
    /**
41
     * @param string[]              $classes
42
     * @param array<string, string> $migrationDirectories
43
     */
44 70
    public function __construct(
45
        array $classes,
46
        array $migrationDirectories,
47
        MigrationFinder $migrationFinder,
48
        MigrationFactory $versionFactory
49
    ) {
50 70
        $this->migrationDirectories = $migrationDirectories;
51 70
        $this->migrationFinder      = $migrationFinder;
52 70
        $this->versionFactory       = $versionFactory;
53
54 70
        $this->registerMigrations($classes);
55 70
    }
56
57 55
    private function registerMigrationInstance(Version $version, AbstractMigration $migration) : AvailableMigration
58
    {
59 55
        if (isset($this->migrations[(string) $version])) {
60 1
            throw DuplicateMigrationVersion::new(
61 1
                (string) $version,
62 1
                (string) $version
63
            );
64
        }
65
66 55
        $this->migrations[(string) $version] = new AvailableMigration($version, $migration);
67
68 55
        return $this->migrations[(string) $version];
69
    }
70
71
    /** @throws MigrationException */
72 6
    public function registerMigration(string $migrationClassName) : AvailableMigration
73
    {
74 6
        $this->ensureMigrationClassExists($migrationClassName);
75
76 6
        $version   = new Version($migrationClassName);
77 6
        $migration = $this->versionFactory->createVersion($migrationClassName);
78
79 6
        return $this->registerMigrationInstance($version, $migration);
80
    }
81
82
    /**
83
     * @param string[] $migrations
84
     *
85
     * @return AvailableMigration[]
86
     */
87 70
    private function registerMigrations(array $migrations) : array
88
    {
89 70
        $versions = [];
90
91 70
        foreach ($migrations as $class) {
92 6
            $versions[] = $this->registerMigration($class);
93
        }
94
95 70
        return $versions;
96
    }
97
98 10
    public function hasMigration(string $version) : bool
99
    {
100 10
        $this->loadMigrationsFromDirectories();
101
102 10
        return isset($this->migrations[$version]);
103
    }
104
105 15
    public function getMigration(Version $version) : AvailableMigration
106
    {
107 15
        $this->loadMigrationsFromDirectories();
108
109 15
        if (! isset($this->migrations[(string) $version])) {
110 4
            throw MigrationClassNotFound::new((string) $version);
111
        }
112
113 12
        return $this->migrations[(string) $version];
114
    }
115
116
    /**
117
     * return a @AvailableMigrationsSet with unordered migration items
118
     */
119 58
    public function getMigrations() : AvailableMigrationsSet
120
    {
121 58
        $this->loadMigrationsFromDirectories();
122
123 58
        return new AvailableMigrationsSet($this->migrations);
124
    }
125
126
    /** @throws MigrationException */
127 6
    private function ensureMigrationClassExists(string $class) : void
128
    {
129 6
        if (! class_exists($class)) {
130
            throw MigrationClassNotFound::new($class);
131
        }
132 6
    }
133
134 61
    private function loadMigrationsFromDirectories() : void
135
    {
136 61
        $migrationDirectories = $this->migrationDirectories;
137
138 61
        if ($this->migrationsLoaded) {
139 38
            return;
140
        }
141
142 61
        $this->migrationsLoaded = true;
143
144 61
        foreach ($migrationDirectories as $namespace => $path) {
145 41
                $migrations = $this->migrationFinder->findMigrations(
146 41
                    $path,
147 41
                    $namespace
148
                );
149 41
                $this->registerMigrations($migrations);
150
        }
151 61
    }
152
}
153