Driver.php 2.64 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
    {
19 20
        [$driverOptions, $connectionOptions] = $this->splitOptions($driverOptions);

Juozas Kaziukenas's avatar
Juozas Kaziukenas committed
21
        return new Connection(
22
            $this->_constructPdoDsn($params, $connectionOptions),
23 24 25 26 27 28 29 30 31
            $username,
            $password,
            $driverOptions
        );
    }

    /**
     * Constructs the Sqlsrv PDO DSN.
     *
32
     * @param mixed[]  $params
33
     * @param string[] $connectionOptions
Benjamin Morel's avatar
Benjamin Morel committed
34 35
     *
     * @return string The DSN.
36
     */
37
    private function _constructPdoDsn(array $params, array $connectionOptions)
38
    {
39
        $dsn = 'sqlsrv:server=';
40

41 42 43
        if (isset($params['host'])) {
            $dsn .= $params['host'];
        }
44

45
        if (isset($params['port']) && ! empty($params['port'])) {
46 47
            $dsn .= ',' . $params['port'];
        }
48

49
        if (isset($params['dbname'])) {
50
            $connectionOptions['Database'] = $params['dbname'];
51 52 53
        }

        if (isset($params['MultipleActiveResultSets'])) {
54
            $connectionOptions['MultipleActiveResultSets'] = $params['MultipleActiveResultSets'] ? 'true' : 'false';
55
        }
56

57
        return $dsn . $this->getConnectionOptionsDsn($connectionOptions);
58 59
    }

60 61 62 63
    /**
     * Separates a connection options from a driver options
     *
     * @param int[]|string[] $options
64
     *
65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98
     * @return int[][]|string[][]
     */
    private function splitOptions(array $options) : array
    {
        $driverOptions     = [];
        $connectionOptions = [];

        foreach ($options as $optionKey => $optionValue) {
            if (is_int($optionKey)) {
                $driverOptions[$optionKey] = $optionValue;
            } else {
                $connectionOptions[$optionKey] = $optionValue;
            }
        }

        return [$driverOptions, $connectionOptions];
    }

    /**
     * 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
99 100 101
    /**
     * {@inheritdoc}
     */
102 103 104 105
    public function getName()
    {
        return 'pdo_sqlsrv';
    }
106
}