Passed
Push — master ( 84168c...36e5aa )
by Jonas
10:19
created

Schema::getFacadeAccessor()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
rs 10
1
<?php
2
3
namespace Staudenmeir\LaravelMergedRelations\Facades;
4
5
use Illuminate\Database\Connection;
6
use Illuminate\Support\Facades\Facade;
7
use RuntimeException;
8
use Staudenmeir\LaravelMergedRelations\Schema\Builders\MySqlBuilder;
9
use Staudenmeir\LaravelMergedRelations\Schema\Builders\PostgresBuilder;
10
use Staudenmeir\LaravelMergedRelations\Schema\Builders\SQLiteBuilder;
11
use Staudenmeir\LaravelMergedRelations\Schema\Builders\SqlServerBuilder;
12
use Staudenmeir\LaravelMigrationViews\Schema\Grammars\MySqlGrammar;
13
use Staudenmeir\LaravelMigrationViews\Schema\Grammars\PostgresGrammar;
14
use Staudenmeir\LaravelMigrationViews\Schema\Grammars\SQLiteGrammar;
15
use Staudenmeir\LaravelMigrationViews\Schema\Grammars\SqlServerGrammar;
16
17
/**
18
 * @method static void createMergeView(string $name, array $relations, bool $duplicates = true, bool $orReplace = false)
19
 * @method static void createMergeViewWithoutDuplicates(string $name, array $relations)
20
 * @method static void createOrReplaceMergeView(string $name, array $relations, bool $duplicates = true)
21
 * @method static void createOrReplaceMergeViewWithoutDuplicates(string $name, array $relations)
22
 */
23
class Schema extends Facade
24
{
25
    /**
26
     * Get the registered name of the component.
27
     *
28
     * @return string
29
     */
30 48
    protected static function getFacadeAccessor()
31
    {
32 48
        return static::class;
33
    }
34
35
    /**
36
     * Get a schema builder instance for a connection.
37
     *
38
     * @param string $name
39
     * @return \Illuminate\Database\Schema\Builder
40
     */
41 8
    public static function connection($name)
42
    {
43 8
        return static::getSchemaBuilder(
44 8
            static::$app['db']->connection($name)
45
        );
46
    }
47
48
    /**
49
     * Get the schema builder.
50
     *
51
     * @param \Illuminate\Database\Connection $connection
52
     * @return \Illuminate\Database\Schema\Builder
53
     */
54 48
    public static function getSchemaBuilder(Connection $connection)
55
    {
56 48
        $driver = $connection->getDriverName();
57
58 48
        switch ($driver) {
59 48
            case 'mysql':
60 12
                $connection->setSchemaGrammar($connection->withTablePrefix(new MySqlGrammar()));
61
62 12
                return new MySqlBuilder($connection);
63 36
            case 'pgsql':
64 12
                $connection->setSchemaGrammar($connection->withTablePrefix(new PostgresGrammar()));
65
66 12
                return new PostgresBuilder($connection);
67 24
            case 'sqlite':
68 12
                $connection->setSchemaGrammar($connection->withTablePrefix(new SQLiteGrammar()));
69
70 12
                return new SQLiteBuilder($connection);
71 12
            case 'sqlsrv':
72 12
                $connection->setSchemaGrammar($connection->withTablePrefix(new SqlServerGrammar()));
73
74 12
                return new SqlServerBuilder($connection);
75
        }
76
77
        throw new RuntimeException('This database is not supported.'); // @codeCoverageIgnore
78
    }
79
}
80