Failed Conditions
Pull Request — 2.10 (#3762)
by Benjamin
09:16
created

Driver::getName()   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 0
Metric Value
dl 0
loc 3
ccs 2
cts 2
cp 1
rs 10
c 0
b 0
f 0
cc 1
eloc 1
nc 1
nop 0
crap 1
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
    public function connect(array $params, $username = null, $password = null, array $driverOptions = [])
18
    {
19
        $pdoOptions = $dsnOptions = [];
20
21
        foreach ($driverOptions as $option => $value) {
22
            if (is_int($option)) {
23
                $pdoOptions[$option] = $value;
24
            } else {
25
                $dsnOptions[$option] = $value;
26
            }
27
        }
28
29
        return new Connection(
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
    private function _constructPdoDsn(array $params, array $connectionOptions)
46
    {
47
        $dsn = 'sqlsrv:server=';
48
49
        if (isset($params['host'])) {
50
            $dsn .= $params['host'];
51
        }
52
53
        if (isset($params['port']) && ! empty($params['port'])) {
54
            $dsn .= ',' . $params['port'];
55
        }
56
57
        if (isset($params['dbname'])) {
58
            $connectionOptions['Database'] = $params['dbname'];
59
        }
60
61
        if (isset($params['MultipleActiveResultSets'])) {
62
            $connectionOptions['MultipleActiveResultSets'] = $params['MultipleActiveResultSets'] ? 'true' : 'false';
63
        }
64
65
        return $dsn . $this->getConnectionOptionsDsn($connectionOptions);
66
    }
67
68
    /**
69
     * Converts a connection options array to the DSN
70
     *
71
     * @param string[] $connectionOptions
72
     */
73
    private function getConnectionOptionsDsn(array $connectionOptions) : string
74
    {
75
        $connectionOptionsDsn = '';
76
77
        foreach ($connectionOptions as $paramName => $paramValue) {
78
            $connectionOptionsDsn .= sprintf(';%s=%s', $paramName, $paramValue);
79
        }
80
81
        return $connectionOptionsDsn;
82
    }
83
84
    /**
85
     * {@inheritdoc}
86
     *
87
     * @deprecated
88
     */
89 29
    public function getName()
90
    {
91 29
        return 'pdo_sqlsrv';
92
    }
93
}
94