Make sqlite LIKE case sensitive on default

This commit is contained in:
Robin Appelman 2014-09-17 13:47:33 +02:00
parent 95815c0b57
commit 60587e9dcd
2 changed files with 45 additions and 0 deletions

View File

@ -89,6 +89,9 @@ class ConnectionFactory {
case 'oci':
$eventManager->addEventSubscriber(new \Doctrine\DBAL\Event\Listeners\OracleSessionInit);
break;
case 'sqlite3':
$eventManager->addEventSubscriber(new SQLiteSessionInit);
break;
}
$connection = \Doctrine\DBAL\DriverManager::getConnection(
array_merge($this->getDefaultConnectionParams($type), $additionalConnectionParams),

View File

@ -0,0 +1,42 @@
<?php
/**
* Copyright (c) 2014 Robin Appelman <icewind@owncloud.com>
* This file is licensed under the Affero General Public License version 3 or
* later.
* See the COPYING-README file.
*/
namespace OC\DB;
use Doctrine\DBAL\Event\ConnectionEventArgs;
use Doctrine\DBAL\Events;
use Doctrine\Common\EventSubscriber;
class SQLiteSessionInit implements EventSubscriber {
/**
* @var bool
*/
private $caseSensitiveLike;
/**
* Configure case sensitive like for each connection
*
* @param bool $caseSensitiveLike
*/
public function __construct($caseSensitiveLike = true) {
$this->caseSensitiveLike = $caseSensitiveLike;
}
/**
* @param ConnectionEventArgs $args
* @return void
*/
public function postConnect(ConnectionEventArgs $args) {
$sensitive = ($this->caseSensitiveLike) ? 'true' : 'false';
$args->getConnection()->executeUpdate('PRAGMA case_sensitive_like = ' . $sensitive);
}
public function getSubscribedEvents() {
return array(Events::postConnect);
}
}