diff options
author | Morris Jobke <hey@morrisjobke.de> | 2017-03-19 14:52:54 -0600 |
---|---|---|
committer | Morris Jobke <hey@morrisjobke.de> | 2017-03-19 14:52:54 -0600 |
commit | d99ce3971b64e89b179ebe32885ac280d49b904f (patch) | |
tree | 980a500cb37ba267e9bd459a7ea320b472865178 /lib/private/DB | |
parent | 3c66ad64e626cb602685a640c235d472f0777a53 (diff) | |
download | nextcloud-server-d99ce3971b64e89b179ebe32885ac280d49b904f.tar.gz nextcloud-server-d99ce3971b64e89b179ebe32885ac280d49b904f.zip |
Namespace and array syntax fixes
* minor fixes in preparation of a bigger DB and config PR
Signed-off-by: Morris Jobke <hey@morrisjobke.de>
Diffstat (limited to 'lib/private/DB')
-rw-r--r-- | lib/private/DB/ConnectionFactory.php | 48 | ||||
-rw-r--r-- | lib/private/DB/MDB2SchemaReader.php | 4 |
2 files changed, 27 insertions, 25 deletions
diff --git a/lib/private/DB/ConnectionFactory.php b/lib/private/DB/ConnectionFactory.php index adb180da0c0..1b53cd4b7c0 100644 --- a/lib/private/DB/ConnectionFactory.php +++ b/lib/private/DB/ConnectionFactory.php @@ -25,9 +25,11 @@ */ namespace OC\DB; +use Doctrine\Common\EventManager; +use Doctrine\DBAL\Configuration; +use Doctrine\DBAL\DriverManager; use Doctrine\DBAL\Event\Listeners\OracleSessionInit; use Doctrine\DBAL\Event\Listeners\SQLSessionInit; -use Doctrine\DBAL\Event\Listeners\MysqlSessionInit; use OCP\IConfig; /** @@ -40,30 +42,30 @@ class ConnectionFactory { * Array mapping DBMS type to default connection parameters passed to * \Doctrine\DBAL\DriverManager::getConnection(). */ - protected $defaultConnectionParams = array( - 'mysql' => array( + protected $defaultConnectionParams = [ + 'mysql' => [ 'adapter' => '\OC\DB\AdapterMySQL', 'charset' => 'UTF8', 'driver' => 'pdo_mysql', 'wrapperClass' => 'OC\DB\Connection', - ), - 'oci' => array( + ], + 'oci' => [ 'adapter' => '\OC\DB\AdapterOCI8', 'charset' => 'AL32UTF8', 'driver' => 'oci8', 'wrapperClass' => 'OC\DB\OracleConnection', - ), - 'pgsql' => array( + ], + 'pgsql' => [ 'adapter' => '\OC\DB\AdapterPgSql', 'driver' => 'pdo_pgsql', 'wrapperClass' => 'OC\DB\Connection', - ), - 'sqlite3' => array( + ], + 'sqlite3' => [ 'adapter' => '\OC\DB\AdapterSqlite', 'driver' => 'pdo_sqlite', 'wrapperClass' => 'OC\DB\Connection', - ), - ); + ], + ]; public function __construct(IConfig $config) { if($config->getSystemValue('mysql.utf8mb4', false)) { @@ -101,14 +103,9 @@ class ConnectionFactory { */ public function getConnection($type, $additionalConnectionParams) { $normalizedType = $this->normalizeType($type); - $eventManager = new \Doctrine\Common\EventManager(); + $eventManager = new EventManager(); switch ($normalizedType) { case 'mysql': - // Send "SET NAMES utf8". Only required on PHP 5.3 below 5.3.6. - // See http://stackoverflow.com/questions/4361459/php-pdo-charset-set-names#4361485 - $eventManager->addEventSubscriber(new MysqlSessionInit( - $this->defaultConnectionParams['mysql']['charset'] - )); $eventManager->addEventSubscriber( new SQLSessionInit("SET SESSION AUTOCOMMIT=1")); break; @@ -125,9 +122,10 @@ class ConnectionFactory { $eventManager->addEventSubscriber(new SQLiteSessionInit(true, $journalMode)); break; } - $connection = \Doctrine\DBAL\DriverManager::getConnection( + /** @var Connection $connection */ + $connection = DriverManager::getConnection( array_merge($this->getDefaultConnectionParams($type), $additionalConnectionParams), - new \Doctrine\DBAL\Configuration(), + new Configuration(), $eventManager ); return $connection; @@ -143,9 +141,11 @@ class ConnectionFactory { } /** - * @brief Checks whether the specified DBMS type is valid. - * @return bool - */ + * Checks whether the specified DBMS type is valid. + * + * @param string $type + * @return bool + */ public function isValidType($type) { $normalizedType = $this->normalizeType($type); return isset($this->defaultConnectionParams[$normalizedType]); @@ -160,10 +160,10 @@ class ConnectionFactory { public function createConnectionParams($config) { $type = $config->getValue('dbtype', 'sqlite'); - $connectionParams = array( + $connectionParams = [ 'user' => $config->getValue('dbuser', ''), 'password' => $config->getValue('dbpassword', ''), - ); + ]; $name = $config->getValue('dbname', 'owncloud'); if ($this->normalizeType($type) === 'sqlite3') { diff --git a/lib/private/DB/MDB2SchemaReader.php b/lib/private/DB/MDB2SchemaReader.php index c198bb31e00..0a51f1b48f2 100644 --- a/lib/private/DB/MDB2SchemaReader.php +++ b/lib/private/DB/MDB2SchemaReader.php @@ -34,6 +34,7 @@ namespace OC\DB; use Doctrine\DBAL\Platforms\AbstractPlatform; use Doctrine\DBAL\Schema\SchemaConfig; use Doctrine\DBAL\Platforms\MySqlPlatform; +use Doctrine\DBAL\Schema\Schema; use OCP\IConfig; class MDB2SchemaReader { @@ -77,7 +78,7 @@ class MDB2SchemaReader { /** * @param string $file - * @return \Doctrine\DBAL\Schema\Schema + * @return Schema * @throws \DomainException */ public function loadSchemaFromFile($file) { @@ -284,6 +285,7 @@ class MDB2SchemaReader { ) { $options['primary'] = true; } + $table->addColumn($name, $type, $options); if (!empty($options['primary']) && $options['primary']) { $table->setPrimaryKey(array($name)); |