Add custom driver & schema manager for PostgreSQL 10

This commit is contained in:
Jeremy Benoist 2017-12-12 12:14:40 +01:00
parent f209798368
commit a1661af17c
No known key found for this signature in database
GPG key ID: BCA73962457ACC3C
8 changed files with 70 additions and 0 deletions

View file

@ -47,6 +47,7 @@ twig:
doctrine: doctrine:
dbal: dbal:
driver: "%database_driver%" driver: "%database_driver%"
driver_class: "%database_driver_class%"
host: "%database_host%" host: "%database_host%"
port: "%database_port%" port: "%database_port%"
dbname: "%database_name%" dbname: "%database_name%"

View file

@ -23,6 +23,7 @@ swiftmailer:
doctrine: doctrine:
dbal: dbal:
driver: "%test_database_driver%" driver: "%test_database_driver%"
driver_class: "%test_database_driver_class%"
host: "%test_database_host%" host: "%test_database_host%"
port: "%test_database_port%" port: "%test_database_port%"
dbname: "%test_database_name%" dbname: "%test_database_name%"

View file

@ -11,6 +11,8 @@ parameters:
# database_password: %env.database_password% # database_password: %env.database_password%
database_driver: pdo_mysql database_driver: pdo_mysql
database_driver_class: ~
# database_driver_class: Wallabag\CoreBundle\Doctrine\DBAL\Driver\CustomPostgreSQLDriver
database_host: 127.0.0.1 database_host: 127.0.0.1
database_port: ~ database_port: ~
database_name: wallabag database_name: wallabag

View file

@ -1,5 +1,6 @@
parameters: parameters:
test_database_driver: pdo_mysql test_database_driver: pdo_mysql
test_database_driver_class: ~
test_database_host: localhost test_database_host: localhost
test_database_port: 3306 test_database_port: 3306
test_database_name: wallabag_test test_database_name: wallabag_test

View file

@ -1,5 +1,6 @@
parameters: parameters:
test_database_driver: pdo_pgsql test_database_driver: pdo_pgsql
test_database_driver_class: Wallabag\CoreBundle\Doctrine\DBAL\Driver\CustomPostgreSQLDriver
test_database_host: localhost test_database_host: localhost
test_database_port: test_database_port:
test_database_name: wallabag_test test_database_name: wallabag_test

View file

@ -1,5 +1,6 @@
parameters: parameters:
test_database_driver: pdo_sqlite test_database_driver: pdo_sqlite
test_database_driver_class: ~
test_database_host: localhost test_database_host: localhost
test_database_port: test_database_port:
test_database_name: ~ test_database_name: ~

View file

@ -0,0 +1,25 @@
<?php
namespace Wallabag\CoreBundle\Doctrine\DBAL\Driver;
use Doctrine\DBAL\Connection;
use Doctrine\DBAL\Driver\PDOPgSql\Driver;
use Wallabag\CoreBundle\Doctrine\DBAL\Schema\CustomPostgreSqlSchemaManager;
/**
* This custom driver allow to use a different schema manager
* So we can fix the PostgreSQL 10 problem.
*
* @see https://github.com/wallabag/wallabag/issues/3479
* @see https://github.com/doctrine/dbal/issues/2868
*/
class CustomPostgreSQLDriver extends Driver
{
/**
* {@inheritdoc}
*/
public function getSchemaManager(Connection $conn)
{
return new CustomPostgreSqlSchemaManager($conn);
}
}

View file

@ -0,0 +1,38 @@
<?php
namespace Wallabag\CoreBundle\Doctrine\DBAL\Schema;
use Doctrine\DBAL\Schema\PostgreSqlSchemaManager;
use Doctrine\DBAL\Schema\Sequence;
/**
* This custom schema manager fix the PostgreSQL 10 problem.
*
* @see https://github.com/wallabag/wallabag/issues/3479
* @see https://github.com/doctrine/dbal/issues/2868
*/
class CustomPostgreSqlSchemaManager extends PostgreSqlSchemaManager
{
/**
* {@inheritdoc}
*/
protected function _getPortableSequenceDefinition($sequence)
{
if ('public' !== $sequence['schemaname']) {
$sequenceName = $sequence['schemaname'] . '.' . $sequence['relname'];
} else {
$sequenceName = $sequence['relname'];
}
$query = 'SELECT min_value, increment_by FROM ' . $this->_platform->quoteIdentifier($sequenceName);
// patch for PostgreSql >= 10
if ((float) ($this->_conn->getWrappedConnection()->getServerVersion()) >= 10) {
$query = "SELECT min_value, increment_by FROM pg_sequences WHERE schemaname = 'public' AND sequencename = " . $this->_conn->quote($sequenceName);
}
$data = $this->_conn->fetchAll($query);
return new Sequence($sequenceName, $data[0]['increment_by'], $data[0]['min_value']);
}
}