Completed
Push — develop ( 72ba3e...de019a )
by Marco
25s queued 12s
created

Driver   A

Complexity

Total Complexity 13

Size/Duplication

Total Lines 78
Duplicated Lines 0 %

Test Coverage

Coverage 86.21%

Importance

Changes 0
Metric Value
wmc 13
eloc 26
dl 0
loc 78
ccs 25
cts 29
cp 0.8621
rs 10
c 0
b 0
f 0

4 Methods

Rating   Name   Duplication   Size   Complexity  
A getName() 0 3 1
A getConnectionOptionsDsn() 0 9 2
B _constructPdoDsn() 0 21 7
A connect() 0 17 3
1
<?php
2
3
namespace Doctrine\DBAL\Driver\PDOSqlsrv;
4
5
use Doctrine\DBAL\Driver\AbstractSQLServerDriver;
6
use function is_int;
7
use function sprintf;
8
9
/**
10
 * The PDO-based Sqlsrv driver.
11
 */
12
class Driver extends AbstractSQLServerDriver
13
{
14
    /**
15
     * {@inheritdoc}
16
     */
17 30
    public function connect(array $params, $username = null, $password = null, array $driverOptions = [])
18
    {
19 30
        $pdoOptions = $dsnOptions = [];
20
21 30
        foreach ($driverOptions as $option => $value) {
22 11
            if (is_int($option)) {
23 10
                $pdoOptions[$option] = $value;
24
            } else {
25 11
                $dsnOptions[$option] = $value;
26
            }
27
        }
28
29 30
        return new Connection(
30 30
            $this->_constructPdoDsn($params, $dsnOptions),
31
            $username,
32
            $password,
33
            $pdoOptions
34
        );
35
    }
36
37
    /**
38
     * Constructs the Sqlsrv PDO DSN.
39
     *
40
     * @param mixed[]  $params
41
     * @param string[] $connectionOptions
42
     *
43
     * @return string The DSN.
44
     */
45 30
    private function _constructPdoDsn(array $params, array $connectionOptions)
46
    {
47 30
        $dsn = 'sqlsrv:server=';
48
49 30
        if (isset($params['host'])) {
50 30
            $dsn .= $params['host'];
51
        }
52
53 30
        if (isset($params['port']) && ! empty($params['port'])) {
54 30
            $dsn .= ',' . $params['port'];
55
        }
56
57 30
        if (isset($params['dbname'])) {
58 30
            $connectionOptions['Database'] = $params['dbname'];
59
        }
60
61 30
        if (isset($params['MultipleActiveResultSets'])) {
62
            $connectionOptions['MultipleActiveResultSets'] = $params['MultipleActiveResultSets'] ? 'true' : 'false';
63
        }
64
65 30
        return $dsn . $this->getConnectionOptionsDsn($connectionOptions);
66
    }
67
68
    /**
69
     * Converts a connection options array to the DSN
70
     *
71
     * @param string[] $connectionOptions
72
     */
73 30
    private function getConnectionOptionsDsn(array $connectionOptions) : string
74
    {
75 30
        $connectionOptionsDsn = '';
76
77 30
        foreach ($connectionOptions as $paramName => $paramValue) {
78 30
            $connectionOptionsDsn .= sprintf(';%s=%s', $paramName, $paramValue);
79
        }
80
81 30
        return $connectionOptionsDsn;
82
    }
83
84
    /**
85
     * {@inheritdoc}
86
     */
87 54
    public function getName()
88
    {
89 54
        return 'pdo_sqlsrv';
90
    }
91
}
92