Driver.php 1.32 KB
Newer Older
1 2
<?php

Michael Moravec's avatar
Michael Moravec committed
3 4
declare(strict_types=1);

5 6
namespace Doctrine\DBAL\Driver\SQLSrv;

7
use Doctrine\DBAL\Driver\AbstractSQLServerDriver;
8
use Doctrine\DBAL\Driver\Connection;
Steve Müller's avatar
Steve Müller committed
9

10
/**
Benjamin Morel's avatar
Benjamin Morel committed
11
 * Driver for ext/sqlsrv.
12
 */
13
final class Driver extends AbstractSQLServerDriver
14
{
Benjamin Morel's avatar
Benjamin Morel committed
15 16 17
    /**
     * {@inheritdoc}
     */
18 19 20 21 22 23
    public function connect(
        array $params,
        string $username = '',
        string $password = '',
        array $driverOptions = []
    ) : Connection {
24
        if (! isset($params['host'])) {
25
            throw new SQLSrvException('Missing "host" in configuration for sqlsrv driver.');
26
        }
27

28 29 30 31
        $serverName = $params['host'];
        if (isset($params['port'])) {
            $serverName .= ', ' . $params['port'];
        }
32 33 34 35

        if (isset($params['dbname'])) {
            $driverOptions['Database'] = $params['dbname'];
        }
36

37 38 39
        if (isset($params['charset'])) {
            $driverOptions['CharacterSet'] = $params['charset'];
        }
40

41
        if ($username !== '') {
Nicolas PAJON's avatar
Nicolas PAJON committed
42 43
            $driverOptions['UID'] = $username;
        }
Nicolas PAJON's avatar
Nicolas PAJON committed
44

45
        if ($password !== '') {
Nicolas PAJON's avatar
Nicolas PAJON committed
46 47
            $driverOptions['PWD'] = $password;
        }
48

49
        if (! isset($driverOptions['ReturnDatesAsStrings'])) {
50 51 52 53 54 55
            $driverOptions['ReturnDatesAsStrings'] = 1;
        }

        return new SQLSrvConnection($serverName, $driverOptions);
    }
}