summaryrefslogtreecommitdiffstats
path: root/lib/private/db/connectionfactory.php
diff options
context:
space:
mode:
authorRoeland Jago Douma <rullzer@owncloud.com>2016-04-15 19:46:34 +0200
committerRoeland Jago Douma <rullzer@owncloud.com>2016-04-15 19:46:34 +0200
commitd09f835dcac66347204ada3def3b8ea9d837f0ab (patch)
tree2cf5d5de1c1ef98313b80cc0251945926bfa0302 /lib/private/db/connectionfactory.php
parentbb71fd6d02fd829542277129e022ef4dae840e1d (diff)
downloadnextcloud-server-d09f835dcac66347204ada3def3b8ea9d837f0ab.tar.gz
nextcloud-server-d09f835dcac66347204ada3def3b8ea9d837f0ab.zip
Move \OC\DB to PSR-4
Besides the statement wrapper that is moved to the legacy folder (namepsace of shame folder)
Diffstat (limited to 'lib/private/db/connectionfactory.php')
-rw-r--r--lib/private/db/connectionfactory.php184
1 files changed, 0 insertions, 184 deletions
diff --git a/lib/private/db/connectionfactory.php b/lib/private/db/connectionfactory.php
deleted file mode 100644
index 0856d8d19c0..00000000000
--- a/lib/private/db/connectionfactory.php
+++ /dev/null
@@ -1,184 +0,0 @@
-<?php
-/**
- * @author Andreas Fischer <bantu@owncloud.com>
- * @author Jörn Friedrich Dreyer <jfd@butonic.de>
- * @author Morris Jobke <hey@morrisjobke.de>
- * @author Robin Appelman <icewind@owncloud.com>
- * @author Thomas Müller <thomas.mueller@tmit.eu>
- *
- * @copyright Copyright (c) 2016, ownCloud, Inc.
- * @license AGPL-3.0
- *
- * This code is free software: you can redistribute it and/or modify
- * it under the terms of the GNU Affero General Public License, version 3,
- * as published by the Free Software Foundation.
- *
- * This program is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- * GNU Affero General Public License for more details.
- *
- * You should have received a copy of the GNU Affero General Public License, version 3,
- * along with this program. If not, see <http://www.gnu.org/licenses/>
- *
- */
-
-namespace OC\DB;
-use Doctrine\DBAL\Event\Listeners\OracleSessionInit;
-use Doctrine\DBAL\Event\Listeners\SQLSessionInit;
-use Doctrine\DBAL\Event\Listeners\MysqlSessionInit;
-
-/**
-* Takes care of creating and configuring Doctrine connections.
-*/
-class ConnectionFactory {
- /**
- * @var array
- *
- * Array mapping DBMS type to default connection parameters passed to
- * \Doctrine\DBAL\DriverManager::getConnection().
- */
- protected $defaultConnectionParams = array(
- 'mysql' => array(
- 'adapter' => '\OC\DB\AdapterMySQL',
- 'charset' => 'UTF8',
- 'driver' => 'pdo_mysql',
- 'wrapperClass' => 'OC\DB\Connection',
- ),
- 'oci' => array(
- 'adapter' => '\OC\DB\AdapterOCI8',
- 'charset' => 'AL32UTF8',
- 'driver' => 'oci8',
- 'wrapperClass' => 'OC\DB\OracleConnection',
- ),
- 'pgsql' => array(
- 'adapter' => '\OC\DB\AdapterPgSql',
- 'driver' => 'pdo_pgsql',
- 'wrapperClass' => 'OC\DB\Connection',
- ),
- 'sqlite3' => array(
- 'adapter' => '\OC\DB\AdapterSqlite',
- 'driver' => 'pdo_sqlite',
- 'wrapperClass' => 'OC\DB\Connection',
- ),
- );
-
- /**
- * @brief Get default connection parameters for a given DBMS.
- * @param string $type DBMS type
- * @throws \InvalidArgumentException If $type is invalid
- * @return array Default connection parameters.
- */
- public function getDefaultConnectionParams($type) {
- $normalizedType = $this->normalizeType($type);
- if (!isset($this->defaultConnectionParams[$normalizedType])) {
- throw new \InvalidArgumentException("Unsupported type: $type");
- }
- $result = $this->defaultConnectionParams[$normalizedType];
- // \PDO::MYSQL_ATTR_FOUND_ROWS may not be defined, e.g. when the MySQL
- // driver is missing. In this case, we won't be able to connect anyway.
- if ($normalizedType === 'mysql' && defined('\PDO::MYSQL_ATTR_FOUND_ROWS')) {
- $result['driverOptions'] = array(
- \PDO::MYSQL_ATTR_FOUND_ROWS => true,
- );
- }
- return $result;
- }
-
- /**
- * @brief Get default connection parameters for a given DBMS.
- * @param string $type DBMS type
- * @param array $additionalConnectionParams Additional connection parameters
- * @return \OC\DB\Connection
- */
- public function getConnection($type, $additionalConnectionParams) {
- $normalizedType = $this->normalizeType($type);
- $eventManager = new \Doctrine\Common\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);
- $eventManager->addEventSubscriber(
- new SQLSessionInit("SET SESSION AUTOCOMMIT=1"));
- break;
- case 'oci':
- $eventManager->addEventSubscriber(new OracleSessionInit);
- break;
- case 'sqlite3':
- $journalMode = $additionalConnectionParams['sqlite.journal_mode'];
- $additionalConnectionParams['platform'] = new OCSqlitePlatform();
- $eventManager->addEventSubscriber(new SQLiteSessionInit(true, $journalMode));
- break;
- }
- $connection = \Doctrine\DBAL\DriverManager::getConnection(
- array_merge($this->getDefaultConnectionParams($type), $additionalConnectionParams),
- new \Doctrine\DBAL\Configuration(),
- $eventManager
- );
- return $connection;
- }
-
- /**
- * @brief Normalize DBMS type
- * @param string $type DBMS type
- * @return string Normalized DBMS type
- */
- public function normalizeType($type) {
- return $type === 'sqlite' ? 'sqlite3' : $type;
- }
-
- /**
- * @brief Checks whether the specified DBMS type is valid.
- * @return bool
- */
- public function isValidType($type) {
- $normalizedType = $this->normalizeType($type);
- return isset($this->defaultConnectionParams[$normalizedType]);
- }
-
- /**
- * Create the connection parameters for the config
- *
- * @param \OC\SystemConfig $config
- * @return array
- */
- public function createConnectionParams($config) {
- $type = $config->getValue('dbtype', 'sqlite');
-
- $connectionParams = array(
- 'user' => $config->getValue('dbuser', ''),
- 'password' => $config->getValue('dbpassword', ''),
- );
- $name = $config->getValue('dbname', 'owncloud');
-
- if ($this->normalizeType($type) === 'sqlite3') {
- $dataDir = $config->getValue("datadirectory", \OC::$SERVERROOT . '/data');
- $connectionParams['path'] = $dataDir . '/' . $name . '.db';
- } else {
- $host = $config->getValue('dbhost', '');
- if (strpos($host, ':')) {
- // Host variable may carry a port or socket.
- list($host, $portOrSocket) = explode(':', $host, 2);
- if (ctype_digit($portOrSocket)) {
- $connectionParams['port'] = $portOrSocket;
- } else {
- $connectionParams['unix_socket'] = $portOrSocket;
- }
- }
- $connectionParams['host'] = $host;
- $connectionParams['dbname'] = $name;
- }
-
- $connectionParams['tablePrefix'] = $config->getValue('dbtableprefix', 'oc_');
- $connectionParams['sqlite.journal_mode'] = $config->getValue('sqlite.journal_mode', 'WAL');
-
- //additional driver options, eg. for mysql ssl
- $driverOptions = $config->getValue('dbdriveroptions', null);
- if ($driverOptions) {
- $connectionParams['driverOptions'] = $driverOptions;
- }
-
- return $connectionParams;
- }
-}