Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
90.00% covered (success)
90.00%
9 / 10
0.00% covered (danger)
0.00%
0 / 1
CRAP
0.00% covered (danger)
0.00%
0 / 1
ConnectionFactory
90.00% covered (success)
90.00%
9 / 10
0.00% covered (danger)
0.00%
0 / 1
7.05
0.00% covered (danger)
0.00%
0 / 1
 __construct
n/a
0 / 0
n/a
0 / 0
1
 create
90.00% covered (success)
90.00%
9 / 10
0.00% covered (danger)
0.00%
0 / 1
6.04
1<?php
2/**
3 * Jingga
4 *
5 * PHP Version 8.1
6 *
7 * @package   phpOMS\DataStorage\Database\Connection
8 * @copyright Dennis Eichhorn
9 * @license   OMS License 2.0
10 * @version   1.0.0
11 * @link      https://jingga.app
12 */
13declare(strict_types=1);
14
15namespace phpOMS\DataStorage\Database\Connection;
16
17use phpOMS\DataStorage\Database\DatabaseType;
18
19/**
20 * Database connection factory.
21 *
22 * @package phpOMS\DataStorage\Database\Connection
23 * @license OMS License 2.0
24 * @link    https://jingga.app
25 * @since   1.0.0
26 */
27final class ConnectionFactory
28{
29    /**
30     * Constructor.
31     *
32     * @since 1.0.0
33     * @codeCoverageIgnore
34     */
35    private function __construct()
36    {
37    }
38
39    /**
40     * Create database connection.
41     *
42     * Overwrites current connection if existing
43     *
44     * @param array{db:string, host?:string, port?:int, login?:string, password?:string, database:string} $dbdata the basic database information for establishing a connection
45     *
46     * @return ConnectionAbstract
47     *
48     * @throws \InvalidArgumentException throws this exception if the database is not supported
49     *
50     * @since 1.0.0
51     */
52    public static function create(array $dbdata) : ConnectionAbstract
53    {
54        switch ($dbdata['db']) {
55            case DatabaseType::MYSQL:
56                return new MysqlConnection($dbdata);
57            case DatabaseType::PGSQL:
58                return new PostgresConnection($dbdata);
59            case DatabaseType::SQLSRV:
60                return new SqlServerConnection($dbdata);
61            case DatabaseType::SQLITE:
62                return new SQLiteConnection($dbdata);
63            default:
64                throw new \InvalidArgumentException('Database "' . $dbdata['db'] . '" is not supported.');
65        }
66    }
67}