Driver.php 2.24 KB
Newer Older
1 2 3 4
<?php

namespace Doctrine\DBAL\Driver\PDOSqlsrv;

5
use Doctrine\DBAL\Driver\AbstractSQLServerDriver;
6 7
use function is_int;
use function sprintf;
Steve Müller's avatar
Steve Müller committed
8

9 10 11
/**
 * The PDO-based Sqlsrv driver.
 */
12
class Driver extends AbstractSQLServerDriver
13
{
Benjamin Morel's avatar
Benjamin Morel committed
14 15 16
    /**
     * {@inheritdoc}
     */
17
    public function connect(array $params, $username = null, $password = null, array $driverOptions = [])
18
    {
Sergei Morozov's avatar
Sergei Morozov committed
19 20 21 22 23 24 25 26 27
        $pdoOptions = $dsnOptions = [];

        foreach ($driverOptions as $option => $value) {
            if (is_int($option)) {
                $pdoOptions[$option] = $value;
            } else {
                $dsnOptions[$option] = $value;
            }
        }
28

Juozas Kaziukenas's avatar
Juozas Kaziukenas committed
29
        return new Connection(
Sergei Morozov's avatar
Sergei Morozov committed
30
            $this->_constructPdoDsn($params, $dsnOptions),
31 32
            $username,
            $password,
Sergei Morozov's avatar
Sergei Morozov committed
33
            $pdoOptions
34 35 36 37 38 39
        );
    }

    /**
     * Constructs the Sqlsrv PDO DSN.
     *
40
     * @param mixed[]  $params
41
     * @param string[] $connectionOptions
Benjamin Morel's avatar
Benjamin Morel committed
42 43
     *
     * @return string The DSN.
44
     */
45
    private function _constructPdoDsn(array $params, array $connectionOptions)
46
    {
47
        $dsn = 'sqlsrv:server=';
48

49 50 51
        if (isset($params['host'])) {
            $dsn .= $params['host'];
        }
52

53
        if (isset($params['port']) && ! empty($params['port'])) {
54 55
            $dsn .= ',' . $params['port'];
        }
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 70 71 72 73 74 75 76 77 78 79 80 81 82 83
    /**
     * Converts a connection options array to the DSN
     *
     * @param string[] $connectionOptions
     */
    private function getConnectionOptionsDsn(array $connectionOptions) : string
    {
        $connectionOptionsDsn = '';

        foreach ($connectionOptions as $paramName => $paramValue) {
            $connectionOptionsDsn .= sprintf(';%s=%s', $paramName, $paramValue);
        }

        return $connectionOptionsDsn;
    }

Benjamin Morel's avatar
Benjamin Morel committed
84 85
    /**
     * {@inheritdoc}
86 87
     *
     * @deprecated
Benjamin Morel's avatar
Benjamin Morel committed
88
     */
89 90 91 92
    public function getName()
    {
        return 'pdo_sqlsrv';
    }
93
}