summaryrefslogtreecommitdiffstats
path: root/lib/private/DB
diff options
context:
space:
mode:
authorMorris Jobke <hey@morrisjobke.de>2017-03-19 14:52:54 -0600
committerMorris Jobke <hey@morrisjobke.de>2017-03-19 14:52:54 -0600
commitd99ce3971b64e89b179ebe32885ac280d49b904f (patch)
tree980a500cb37ba267e9bd459a7ea320b472865178 /lib/private/DB
parent3c66ad64e626cb602685a640c235d472f0777a53 (diff)
downloadnextcloud-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.php48
-rw-r--r--lib/private/DB/MDB2SchemaReader.php4
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));