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

namespace Doctrine\DBAL\Driver\PDOSqlsrv;

5
use Doctrine\DBAL\Driver\AbstractSQLServerDriver;
6
use Doctrine\DBAL\Driver\AbstractSQLServerDriver\PortWithoutHost;
7

8 9
use function is_int;
use function sprintf;
Steve Müller's avatar
Steve Müller committed
10

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

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

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

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

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

54 55 56 57 58
            if (isset($params['port'])) {
                $dsn .= ',' . $params['port'];
            }
        } elseif (isset($params['port'])) {
            throw PortWithoutHost::new();
59
        }
60

61
        if (isset($params['dbname'])) {
62
            $connectionOptions['Database'] = $params['dbname'];
63 64 65
        }

        if (isset($params['MultipleActiveResultSets'])) {
66
            $connectionOptions['MultipleActiveResultSets'] = $params['MultipleActiveResultSets'] ? 'true' : 'false';
67
        }
68

69
        return $dsn . $this->getConnectionOptionsDsn($connectionOptions);
70 71
    }

72 73 74 75 76
    /**
     * Converts a connection options array to the DSN
     *
     * @param string[] $connectionOptions
     */
77
    private function getConnectionOptionsDsn(array $connectionOptions): string
78 79 80 81 82 83 84 85 86 87
    {
        $connectionOptionsDsn = '';

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

        return $connectionOptionsDsn;
    }

Benjamin Morel's avatar
Benjamin Morel committed
88 89
    /**
     * {@inheritdoc}
90 91
     *
     * @deprecated
Benjamin Morel's avatar
Benjamin Morel committed
92
     */
93 94 95 96
    public function getName()
    {
        return 'pdo_sqlsrv';
    }
97
}