split db logic from settings manager
Signed-off-by: Robin Appelman <robin@icewind.nl>
This commit is contained in:
parent
b399ad2fee
commit
c4358ff9fd
|
@ -791,7 +791,8 @@ class Server extends ServerContainer implements IServerContainer {
|
||||||
$c->getConfig(),
|
$c->getConfig(),
|
||||||
$c->getEncryptionManager(),
|
$c->getEncryptionManager(),
|
||||||
$c->getUserManager(),
|
$c->getUserManager(),
|
||||||
$c->getLockingProvider()
|
$c->getLockingProvider(),
|
||||||
|
new \OC\Settings\Mapper($c->getDatabaseConnection())
|
||||||
);
|
);
|
||||||
return $manager;
|
return $manager;
|
||||||
});
|
});
|
||||||
|
|
|
@ -23,23 +23,23 @@
|
||||||
|
|
||||||
namespace OC\Settings\Admin;
|
namespace OC\Settings\Admin;
|
||||||
|
|
||||||
use OC\Encryption\Manager;
|
|
||||||
use OCP\AppFramework\Http\TemplateResponse;
|
use OCP\AppFramework\Http\TemplateResponse;
|
||||||
|
use OCP\Encryption\IManager;
|
||||||
use OCP\IUserManager;
|
use OCP\IUserManager;
|
||||||
use OCP\Settings\ISettings;
|
use OCP\Settings\ISettings;
|
||||||
|
|
||||||
class Encryption implements ISettings {
|
class Encryption implements ISettings {
|
||||||
/** @var Manager */
|
/** @var IManager */
|
||||||
private $manager;
|
private $manager;
|
||||||
|
|
||||||
/** @var IUserManager */
|
/** @var IUserManager */
|
||||||
private $userManager;
|
private $userManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param Manager $manager
|
* @param IManager $manager
|
||||||
* @param IUserManager $userManager
|
* @param IUserManager $userManager
|
||||||
*/
|
*/
|
||||||
public function __construct(Manager $manager, IUserManager $userManager) {
|
public function __construct(IManager $manager, IUserManager $userManager) {
|
||||||
$this->manager = $manager;
|
$this->manager = $manager;
|
||||||
$this->userManager = $userManager;
|
$this->userManager = $userManager;
|
||||||
}
|
}
|
||||||
|
|
|
@ -43,6 +43,8 @@ class Manager implements IManager {
|
||||||
private $log;
|
private $log;
|
||||||
/** @var IDBConnection */
|
/** @var IDBConnection */
|
||||||
private $dbc;
|
private $dbc;
|
||||||
|
/** @var Mapper */
|
||||||
|
private $mapper;
|
||||||
/** @var IL10N */
|
/** @var IL10N */
|
||||||
private $l;
|
private $l;
|
||||||
/** @var IConfig */
|
/** @var IConfig */
|
||||||
|
@ -62,6 +64,8 @@ class Manager implements IManager {
|
||||||
* @param EncryptionManager $encryptionManager
|
* @param EncryptionManager $encryptionManager
|
||||||
* @param IUserManager $userManager
|
* @param IUserManager $userManager
|
||||||
* @param ILockingProvider $lockingProvider
|
* @param ILockingProvider $lockingProvider
|
||||||
|
* @param Mapper $mapper
|
||||||
|
* @internal param IDBConnection $dbc
|
||||||
*/
|
*/
|
||||||
public function __construct(
|
public function __construct(
|
||||||
ILogger $log,
|
ILogger $log,
|
||||||
|
@ -70,10 +74,12 @@ class Manager implements IManager {
|
||||||
IConfig $config,
|
IConfig $config,
|
||||||
EncryptionManager $encryptionManager,
|
EncryptionManager $encryptionManager,
|
||||||
IUserManager $userManager,
|
IUserManager $userManager,
|
||||||
ILockingProvider $lockingProvider
|
ILockingProvider $lockingProvider,
|
||||||
|
Mapper $mapper
|
||||||
) {
|
) {
|
||||||
$this->log = $log;
|
$this->log = $log;
|
||||||
$this->dbc = $dbc;
|
$this->dbc = $dbc;
|
||||||
|
$this->mapper = $mapper;
|
||||||
$this->l = $l;
|
$this->l = $l;
|
||||||
$this->config = $config;
|
$this->config = $config;
|
||||||
$this->encryptionManager = $encryptionManager;
|
$this->encryptionManager = $encryptionManager;
|
||||||
|
@ -105,44 +111,27 @@ class Manager implements IManager {
|
||||||
$appInfo = \OC_App::getAppInfo($appId); // hello static legacy
|
$appInfo = \OC_App::getAppInfo($appId); // hello static legacy
|
||||||
|
|
||||||
if (isset($appInfo['settings'][IManager::KEY_ADMIN_SECTION])) {
|
if (isset($appInfo['settings'][IManager::KEY_ADMIN_SECTION])) {
|
||||||
$this->remove(self::TABLE_ADMIN_SECTIONS, trim($appInfo['settings'][IManager::KEY_ADMIN_SECTION], '\\'));
|
$this->mapper->remove(self::TABLE_ADMIN_SECTIONS, trim($appInfo['settings'][IManager::KEY_ADMIN_SECTION], '\\'));
|
||||||
}
|
}
|
||||||
if (isset($appInfo['settings'][IManager::KEY_ADMIN_SETTINGS])) {
|
if (isset($appInfo['settings'][IManager::KEY_ADMIN_SETTINGS])) {
|
||||||
$this->remove(self::TABLE_ADMIN_SETTINGS, trim($appInfo['settings'][IManager::KEY_ADMIN_SETTINGS], '\\'));
|
$this->mapper->remove(self::TABLE_ADMIN_SETTINGS, trim($appInfo['settings'][IManager::KEY_ADMIN_SETTINGS], '\\'));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public function checkForOrphanedClassNames() {
|
public function checkForOrphanedClassNames() {
|
||||||
$tables = [self::TABLE_ADMIN_SECTIONS, self::TABLE_ADMIN_SETTINGS];
|
$tables = [self::TABLE_ADMIN_SECTIONS, self::TABLE_ADMIN_SETTINGS];
|
||||||
foreach ($tables as $table) {
|
foreach ($tables as $table) {
|
||||||
$classes = $this->getClasses($table);
|
$classes = $this->mapper->getClasses($table);
|
||||||
foreach ($classes as $className) {
|
foreach ($classes as $className) {
|
||||||
try {
|
try {
|
||||||
\OC::$server->query($className);
|
\OC::$server->query($className);
|
||||||
} catch (QueryException $e) {
|
} catch (QueryException $e) {
|
||||||
$this->remove($table, $className);
|
$this->mapper->remove($table, $className);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* returns the registerd classes in the given table
|
|
||||||
*
|
|
||||||
* @param $table
|
|
||||||
* @return string[]
|
|
||||||
*/
|
|
||||||
private function getClasses($table) {
|
|
||||||
$q = $this->dbc->getQueryBuilder();
|
|
||||||
$resultStatement = $q->select('class')
|
|
||||||
->from($table)
|
|
||||||
->execute();
|
|
||||||
$data = $resultStatement->fetchAll();
|
|
||||||
$resultStatement->closeCursor();
|
|
||||||
|
|
||||||
return array_map(function($row) { return $row['class']; }, $data);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $sectionClassName
|
* @param string $sectionClassName
|
||||||
*/
|
*/
|
||||||
|
@ -173,7 +162,7 @@ class Manager implements IManager {
|
||||||
}
|
}
|
||||||
|
|
||||||
private function addAdminSection(ISection $section) {
|
private function addAdminSection(ISection $section) {
|
||||||
$this->add(self::TABLE_ADMIN_SECTIONS, [
|
$this->mapper->add(self::TABLE_ADMIN_SECTIONS, [
|
||||||
'id' => $section->getID(),
|
'id' => $section->getID(),
|
||||||
'class' => get_class($section),
|
'class' => get_class($section),
|
||||||
'priority' => $section->getPriority(),
|
'priority' => $section->getPriority(),
|
||||||
|
@ -181,28 +170,15 @@ class Manager implements IManager {
|
||||||
}
|
}
|
||||||
|
|
||||||
private function addAdminSettings(ISettings $settings) {
|
private function addAdminSettings(ISettings $settings) {
|
||||||
$this->add(self::TABLE_ADMIN_SETTINGS, [
|
$this->mapper->add(self::TABLE_ADMIN_SETTINGS, [
|
||||||
'class' => get_class($settings),
|
'class' => get_class($settings),
|
||||||
'section' => $settings->getSection(),
|
'section' => $settings->getSection(),
|
||||||
'priority' => $settings->getPriority(),
|
'priority' => $settings->getPriority(),
|
||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* @param string $table
|
|
||||||
* @param array $values
|
|
||||||
*/
|
|
||||||
private function add($table, array $values) {
|
|
||||||
$query = $this->dbc->getQueryBuilder();
|
|
||||||
$values = array_map(function($value) use ($query) {
|
|
||||||
return $query->createNamedParameter($value);
|
|
||||||
}, $values);
|
|
||||||
$query->insert($table)->values($values);
|
|
||||||
$query->execute();
|
|
||||||
}
|
|
||||||
|
|
||||||
private function updateAdminSettings(ISettings $settings) {
|
private function updateAdminSettings(ISettings $settings) {
|
||||||
$this->update(
|
$this->mapper->update(
|
||||||
self::TABLE_ADMIN_SETTINGS,
|
self::TABLE_ADMIN_SETTINGS,
|
||||||
'class',
|
'class',
|
||||||
get_class($settings),
|
get_class($settings),
|
||||||
|
@ -214,7 +190,7 @@ class Manager implements IManager {
|
||||||
}
|
}
|
||||||
|
|
||||||
private function updateAdminSection(ISection $section) {
|
private function updateAdminSection(ISection $section) {
|
||||||
$this->update(
|
$this->mapper->update(
|
||||||
self::TABLE_ADMIN_SECTIONS,
|
self::TABLE_ADMIN_SECTIONS,
|
||||||
'class',
|
'class',
|
||||||
get_class($section),
|
get_class($section),
|
||||||
|
@ -225,24 +201,12 @@ class Manager implements IManager {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
private function update($table, $idCol, $id, $values) {
|
|
||||||
$query = $this->dbc->getQueryBuilder();
|
|
||||||
$query->update($table);
|
|
||||||
foreach($values as $key => $value) {
|
|
||||||
$query->set($key, $query->createNamedParameter($value));
|
|
||||||
}
|
|
||||||
$query
|
|
||||||
->where($query->expr()->eq($idCol, $query->createParameter($idCol)))
|
|
||||||
->setParameter($idCol, $id)
|
|
||||||
->execute();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @param string $className
|
* @param string $className
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
private function hasAdminSection($className) {
|
private function hasAdminSection($className) {
|
||||||
return $this->has(self::TABLE_ADMIN_SECTIONS, $className);
|
return $this->mapper->has(self::TABLE_ADMIN_SECTIONS, $className);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -250,40 +214,7 @@ class Manager implements IManager {
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
private function hasAdminSettings($className) {
|
private function hasAdminSettings($className) {
|
||||||
return $this->has(self::TABLE_ADMIN_SETTINGS, $className);
|
return $this->mapper->has(self::TABLE_ADMIN_SETTINGS, $className);
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @param string $table
|
|
||||||
* @param string $className
|
|
||||||
* @return bool
|
|
||||||
*/
|
|
||||||
private function has($table, $className) {
|
|
||||||
$query = $this->dbc->getQueryBuilder();
|
|
||||||
$query->select('class')
|
|
||||||
->from($table)
|
|
||||||
->where($query->expr()->eq('class', $query->createNamedParameter($className)))
|
|
||||||
->setMaxResults(1);
|
|
||||||
|
|
||||||
$result = $query->execute();
|
|
||||||
$row = $result->fetch();
|
|
||||||
$result->closeCursor();
|
|
||||||
|
|
||||||
return (bool) $row;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* deletes an settings or admin entry from the given table
|
|
||||||
*
|
|
||||||
* @param $table
|
|
||||||
* @param $className
|
|
||||||
*/
|
|
||||||
private function remove($table, $className) {
|
|
||||||
$query = $this->dbc->getQueryBuilder();
|
|
||||||
$query->delete($table)
|
|
||||||
->where($query->expr()->eq('class', $query->createNamedParameter($className)));
|
|
||||||
|
|
||||||
$query->execute();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private function setupAdminSettings($settingsClassName) {
|
private function setupAdminSettings($settingsClassName) {
|
||||||
|
@ -336,16 +267,9 @@ class Manager implements IManager {
|
||||||
99 => [new Section('tips-tricks', $this->l->t('Tips & tricks'), 0)],
|
99 => [new Section('tips-tricks', $this->l->t('Tips & tricks'), 0)],
|
||||||
];
|
];
|
||||||
|
|
||||||
$query = $this->dbc->getQueryBuilder();
|
$rows = $this->mapper->getAdminSectionsFromDB();
|
||||||
$query->selectDistinct('s.class')
|
|
||||||
->addSelect('s.priority')
|
|
||||||
->from(self::TABLE_ADMIN_SECTIONS, 's')
|
|
||||||
->from(self::TABLE_ADMIN_SETTINGS, 'f')
|
|
||||||
->where($query->expr()->eq('s.id', 'f.section'))
|
|
||||||
;
|
|
||||||
$result = $query->execute();
|
|
||||||
|
|
||||||
while($row = $result->fetch()) {
|
foreach ($rows as $row) {
|
||||||
if (!isset($sections[$row['priority']])) {
|
if (!isset($sections[$row['priority']])) {
|
||||||
$sections[$row['priority']] = [];
|
$sections[$row['priority']] = [];
|
||||||
}
|
}
|
||||||
|
@ -355,12 +279,16 @@ class Manager implements IManager {
|
||||||
// skip
|
// skip
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$result->closeCursor();
|
|
||||||
|
|
||||||
ksort($sections);
|
ksort($sections);
|
||||||
|
|
||||||
return $sections;
|
return $sections;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $section
|
||||||
|
* @return ISection[]
|
||||||
|
*/
|
||||||
private function getBuiltInAdminSettings($section) {
|
private function getBuiltInAdminSettings($section) {
|
||||||
$forms = [];
|
$forms = [];
|
||||||
try {
|
try {
|
||||||
|
@ -397,15 +325,14 @@ class Manager implements IManager {
|
||||||
return $forms;
|
return $forms;
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getAdminSettingsFromDB($section, &$settings) {
|
/**
|
||||||
$query = $this->dbc->getQueryBuilder();
|
* @inheritdoc
|
||||||
$query->select(['class', 'priority'])
|
*/
|
||||||
->from(self::TABLE_ADMIN_SETTINGS)
|
public function getAdminSettings($section) {
|
||||||
->where($query->expr()->eq('section', $this->dbc->getQueryBuilder()->createParameter('section')))
|
$settings = $this->getBuiltInAdminSettings($section);
|
||||||
->setParameter('section', $section);
|
$dbRows = $this->mapper->getAdminSettingsFromDB($section);
|
||||||
|
|
||||||
$result = $query->execute();
|
foreach ($dbRows as $row) {
|
||||||
while($row = $result->fetch()) {
|
|
||||||
if (!isset($settings[$row['priority']])) {
|
if (!isset($settings[$row['priority']])) {
|
||||||
$settings[$row['priority']] = [];
|
$settings[$row['priority']] = [];
|
||||||
}
|
}
|
||||||
|
@ -415,17 +342,8 @@ class Manager implements IManager {
|
||||||
// skip
|
// skip
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$result->closeCursor();
|
|
||||||
|
|
||||||
ksort($settings);
|
ksort($settings);
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* @inheritdoc
|
|
||||||
*/
|
|
||||||
public function getAdminSettings($section) {
|
|
||||||
$settings = $this->getBuiltInAdminSettings($section);
|
|
||||||
$this->getAdminSettingsFromDB($section, $settings);
|
|
||||||
return $settings;
|
return $settings;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,144 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2016 Robin Appelman <robin@icewind.nl>
|
||||||
|
*
|
||||||
|
* @author Robin Appelman <robin@icewind.nl>
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace OC\Settings;
|
||||||
|
|
||||||
|
use OCP\IDBConnection;
|
||||||
|
|
||||||
|
class Mapper {
|
||||||
|
const TABLE_ADMIN_SETTINGS = 'admin_settings';
|
||||||
|
const TABLE_ADMIN_SECTIONS = 'admin_sections';
|
||||||
|
|
||||||
|
/** @var IDBConnection */
|
||||||
|
private $dbc;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param IDBConnection $dbc
|
||||||
|
*/
|
||||||
|
public function __construct(IDBConnection $dbc) {
|
||||||
|
$this->dbc = $dbc;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAdminSettingsFromDB($section) {
|
||||||
|
$query = $this->dbc->getQueryBuilder();
|
||||||
|
$query->select(['class', 'priority'])
|
||||||
|
->from(self::TABLE_ADMIN_SETTINGS)
|
||||||
|
->where($query->expr()->eq('section', $this->dbc->getQueryBuilder()->createParameter('section')))
|
||||||
|
->setParameter('section', $section);
|
||||||
|
|
||||||
|
$result = $query->execute();
|
||||||
|
return $result->fetchAll();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function getAdminSectionsFromDB() {
|
||||||
|
$query = $this->dbc->getQueryBuilder();
|
||||||
|
$query->selectDistinct('s.class')
|
||||||
|
->addSelect('s.priority')
|
||||||
|
->from(self::TABLE_ADMIN_SECTIONS, 's')
|
||||||
|
->from(self::TABLE_ADMIN_SETTINGS, 'f')
|
||||||
|
->where($query->expr()->eq('s.id', 'f.section'));
|
||||||
|
$result = $query->execute();
|
||||||
|
return array_map(function ($row) {
|
||||||
|
$row['priority'] = (int)$row['priority'];
|
||||||
|
return $row;
|
||||||
|
}, $result->fetchAll());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $table
|
||||||
|
* @param array $values
|
||||||
|
*/
|
||||||
|
public function add($table, array $values) {
|
||||||
|
$query = $this->dbc->getQueryBuilder();
|
||||||
|
$values = array_map(function ($value) use ($query) {
|
||||||
|
return $query->createNamedParameter($value);
|
||||||
|
}, $values);
|
||||||
|
$query->insert($table)->values($values);
|
||||||
|
$query->execute();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* returns the registered classes in the given table
|
||||||
|
*
|
||||||
|
* @param $table
|
||||||
|
* @return string[]
|
||||||
|
*/
|
||||||
|
public function getClasses($table) {
|
||||||
|
$q = $this->dbc->getQueryBuilder();
|
||||||
|
$resultStatement = $q->select('class')
|
||||||
|
->from($table)
|
||||||
|
->execute();
|
||||||
|
$data = $resultStatement->fetchAll();
|
||||||
|
$resultStatement->closeCursor();
|
||||||
|
|
||||||
|
return array_map(function ($row) {
|
||||||
|
return $row['class'];
|
||||||
|
}, $data);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param string $table
|
||||||
|
* @param string $className
|
||||||
|
* @return bool
|
||||||
|
*/
|
||||||
|
public function has($table, $className) {
|
||||||
|
$query = $this->dbc->getQueryBuilder();
|
||||||
|
$query->select('class')
|
||||||
|
->from($table)
|
||||||
|
->where($query->expr()->eq('class', $query->createNamedParameter($className)))
|
||||||
|
->setMaxResults(1);
|
||||||
|
|
||||||
|
$result = $query->execute();
|
||||||
|
$row = $result->fetch();
|
||||||
|
$result->closeCursor();
|
||||||
|
|
||||||
|
return (bool)$row;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* deletes an settings or admin entry from the given table
|
||||||
|
*
|
||||||
|
* @param $table
|
||||||
|
* @param $className
|
||||||
|
*/
|
||||||
|
public function remove($table, $className) {
|
||||||
|
$query = $this->dbc->getQueryBuilder();
|
||||||
|
$query->delete($table)
|
||||||
|
->where($query->expr()->eq('class', $query->createNamedParameter($className)));
|
||||||
|
|
||||||
|
$query->execute();
|
||||||
|
}
|
||||||
|
|
||||||
|
public function update($table, $idCol, $id, $values) {
|
||||||
|
$query = $this->dbc->getQueryBuilder();
|
||||||
|
$query->update($table);
|
||||||
|
foreach ($values as $key => $value) {
|
||||||
|
$query->set($key, $query->createNamedParameter($value));
|
||||||
|
}
|
||||||
|
$query
|
||||||
|
->where($query->expr()->eq($idCol, $query->createParameter($idCol)))
|
||||||
|
->setParameter($idCol, $id)
|
||||||
|
->execute();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -25,6 +25,7 @@ namespace Tests\Settings;
|
||||||
|
|
||||||
use OC\Settings\Admin\Sharing;
|
use OC\Settings\Admin\Sharing;
|
||||||
use OC\Settings\Manager;
|
use OC\Settings\Manager;
|
||||||
|
use OC\Settings\Mapper;
|
||||||
use OC\Settings\Section;
|
use OC\Settings\Section;
|
||||||
use OCP\Encryption\IManager;
|
use OCP\Encryption\IManager;
|
||||||
use OCP\IConfig;
|
use OCP\IConfig;
|
||||||
|
@ -36,22 +37,24 @@ use OCP\Lock\ILockingProvider;
|
||||||
use Test\TestCase;
|
use Test\TestCase;
|
||||||
|
|
||||||
class ManagerTest extends TestCase {
|
class ManagerTest extends TestCase {
|
||||||
/** @var Manager */
|
/** @var Manager|\PHPUnit_Framework_MockObject_MockObject */
|
||||||
private $manager;
|
private $manager;
|
||||||
/** @var ILogger */
|
/** @var ILogger|\PHPUnit_Framework_MockObject_MockObject */
|
||||||
private $logger;
|
private $logger;
|
||||||
/** @var IDBConnection */
|
/** @var IDBConnection|\PHPUnit_Framework_MockObject_MockObject */
|
||||||
private $dbConnection;
|
private $dbConnection;
|
||||||
/** @var IL10N */
|
/** @var IL10N|\PHPUnit_Framework_MockObject_MockObject */
|
||||||
private $l10n;
|
private $l10n;
|
||||||
/** @var IConfig */
|
/** @var IConfig|\PHPUnit_Framework_MockObject_MockObject */
|
||||||
private $config;
|
private $config;
|
||||||
/** @var IManager */
|
/** @var IManager|\PHPUnit_Framework_MockObject_MockObject */
|
||||||
private $encryptionManager;
|
private $encryptionManager;
|
||||||
/** @var IUserManager */
|
/** @var IUserManager|\PHPUnit_Framework_MockObject_MockObject */
|
||||||
private $userManager;
|
private $userManager;
|
||||||
/** @var ILockingProvider */
|
/** @var ILockingProvider|\PHPUnit_Framework_MockObject_MockObject */
|
||||||
private $lockingProvider;
|
private $lockingProvider;
|
||||||
|
/** @var Mapper|\PHPUnit_Framework_MockObject_MockObject */
|
||||||
|
private $mapper;
|
||||||
|
|
||||||
public function setUp() {
|
public function setUp() {
|
||||||
parent::setUp();
|
parent::setUp();
|
||||||
|
@ -63,6 +66,7 @@ class ManagerTest extends TestCase {
|
||||||
$this->encryptionManager = $this->getMockBuilder('\OCP\Encryption\IManager')->getMock();
|
$this->encryptionManager = $this->getMockBuilder('\OCP\Encryption\IManager')->getMock();
|
||||||
$this->userManager = $this->getMockBuilder('\OCP\IUserManager')->getMock();
|
$this->userManager = $this->getMockBuilder('\OCP\IUserManager')->getMock();
|
||||||
$this->lockingProvider = $this->getMockBuilder('\OCP\Lock\ILockingProvider')->getMock();
|
$this->lockingProvider = $this->getMockBuilder('\OCP\Lock\ILockingProvider')->getMock();
|
||||||
|
$this->mapper = $this->getMockBuilder(Mapper::class)->disableOriginalConstructor()->getMock();
|
||||||
|
|
||||||
$this->manager = new Manager(
|
$this->manager = new Manager(
|
||||||
$this->logger,
|
$this->logger,
|
||||||
|
@ -71,63 +75,49 @@ class ManagerTest extends TestCase {
|
||||||
$this->config,
|
$this->config,
|
||||||
$this->encryptionManager,
|
$this->encryptionManager,
|
||||||
$this->userManager,
|
$this->userManager,
|
||||||
$this->lockingProvider
|
$this->lockingProvider,
|
||||||
|
$this->mapper
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testSetupSettings() {
|
public function testSetupSettingsUpdate() {
|
||||||
$qb = $this->getMockBuilder('\OCP\DB\QueryBuilder\IQueryBuilder')->getMock();
|
$this->mapper->expects($this->any())
|
||||||
$qb
|
->method('has')
|
||||||
->expects($this->once())
|
->with('admin_settings', 'OCA\Files\Settings\Admin')
|
||||||
->method('select')
|
->will($this->returnValue(true));
|
||||||
->with('class')
|
|
||||||
->willReturn($qb);
|
|
||||||
$this->dbConnection
|
|
||||||
->expects($this->at(0))
|
|
||||||
->method('getQueryBuilder')
|
|
||||||
->willReturn($qb);
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('from')
|
|
||||||
->with('admin_settings')
|
|
||||||
->willReturn($qb);
|
|
||||||
$expressionBuilder = $this->getMockBuilder('\OCP\DB\QueryBuilder\IExpressionBuilder')->getMock();
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('expr')
|
|
||||||
->willReturn($expressionBuilder);
|
|
||||||
$param = $this->getMockBuilder('\OCP\DB\QueryBuilder\IParameter')->getMock();
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('createNamedParameter')
|
|
||||||
->with('OCA\Files\Settings\Admin')
|
|
||||||
->willReturn($param);
|
|
||||||
$expressionBuilder
|
|
||||||
->expects($this->once())
|
|
||||||
->method('eq')
|
|
||||||
->with('class', $param)
|
|
||||||
->willReturn('myString');
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('where')
|
|
||||||
->with('myString')
|
|
||||||
->willReturn($qb);
|
|
||||||
$stmt = $this->getMockBuilder('\Doctrine\DBAL\Driver\Statement')->getMock();
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('execute')
|
|
||||||
->willReturn($stmt);
|
|
||||||
|
|
||||||
$qb1 = $this->getMockBuilder('\OCP\DB\QueryBuilder\IQueryBuilder')->getMock();
|
$this->mapper->expects($this->once())
|
||||||
$qb1
|
->method('update')
|
||||||
->expects($this->once())
|
->with('admin_settings',
|
||||||
->method('insert')
|
'class',
|
||||||
->with('admin_settings')
|
'OCA\Files\Settings\Admin', [
|
||||||
->willReturn($qb1);
|
'section' => 'additional',
|
||||||
$this->dbConnection
|
'priority' => 5
|
||||||
->expects($this->at(1))
|
]);
|
||||||
->method('getQueryBuilder')
|
$this->mapper->expects($this->never())
|
||||||
->willReturn($qb1);
|
->method('add');
|
||||||
|
|
||||||
|
$this->manager->setupSettings([
|
||||||
|
'admin' => 'OCA\Files\Settings\Admin',
|
||||||
|
]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testSetupSettingsAdd() {
|
||||||
|
$this->mapper->expects($this->any())
|
||||||
|
->method('has')
|
||||||
|
->with('admin_settings', 'OCA\Files\Settings\Admin')
|
||||||
|
->will($this->returnValue(false));
|
||||||
|
|
||||||
|
$this->mapper->expects($this->once())
|
||||||
|
->method('add')
|
||||||
|
->with('admin_settings', [
|
||||||
|
'class' => 'OCA\Files\Settings\Admin',
|
||||||
|
'section' => 'additional',
|
||||||
|
'priority' => 5
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->mapper->expects($this->never())
|
||||||
|
->method('update');
|
||||||
|
|
||||||
$this->manager->setupSettings([
|
$this->manager->setupSettings([
|
||||||
'admin' => 'OCA\Files\Settings\Admin',
|
'admin' => 'OCA\Files\Settings\Admin',
|
||||||
|
@ -135,44 +125,49 @@ class ManagerTest extends TestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testGetAdminSections() {
|
public function testGetAdminSections() {
|
||||||
$qb = $this->getMockBuilder('\OCP\DB\QueryBuilder\IQueryBuilder')->getMock();
|
|
||||||
$expr = $this->getMockBuilder('OCP\DB\QueryBuilder\IExpressionBuilder')->getMock();
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('selectDistinct')
|
|
||||||
->with('s.class')
|
|
||||||
->willReturn($qb);
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('addSelect')
|
|
||||||
->with('s.priority')
|
|
||||||
->willReturn($qb);
|
|
||||||
$qb
|
|
||||||
->expects($this->exactly(2))
|
|
||||||
->method('from')
|
|
||||||
->willReturn($qb);
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('expr')
|
|
||||||
->willReturn($expr);
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('where')
|
|
||||||
->willReturn($qb);
|
|
||||||
$stmt = $this->getMockBuilder('\Doctrine\DBAL\Driver\Statement')->getMock();
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('execute')
|
|
||||||
->willReturn($stmt);
|
|
||||||
$this->dbConnection
|
|
||||||
->expects($this->once())
|
|
||||||
->method('getQueryBuilder')
|
|
||||||
->willReturn($qb);
|
|
||||||
$this->l10n
|
$this->l10n
|
||||||
->expects($this->any())
|
->expects($this->any())
|
||||||
->method('t')
|
->method('t')
|
||||||
->will($this->returnArgument(0));
|
->will($this->returnArgument(0));
|
||||||
|
|
||||||
|
$this->mapper->expects($this->once())
|
||||||
|
->method('getAdminSectionsFromDB')
|
||||||
|
->will($this->returnValue([
|
||||||
|
['class' => '\OCA\LogReader\Settings\Section', 'priority' => 90]
|
||||||
|
]));
|
||||||
|
|
||||||
|
$this->mapper->expects($this->once())
|
||||||
|
->method('getAdminSettingsCountFromDB')
|
||||||
|
->will($this->returnValue([
|
||||||
|
'logging' => 1
|
||||||
|
]));
|
||||||
|
|
||||||
|
$this->assertEquals([
|
||||||
|
0 => [new Section('server', 'Server settings', 0)],
|
||||||
|
5 => [new Section('sharing', 'Sharing', 0)],
|
||||||
|
45 => [new Section('encryption', 'Encryption', 0)],
|
||||||
|
90 => [new \OCA\LogReader\Settings\Section(\OC::$server->getL10N('logreader'))],
|
||||||
|
98 => [new Section('additional', 'Additional settings', 0)],
|
||||||
|
99 => [new Section('tips-tricks', 'Tips & tricks', 0)],
|
||||||
|
], $this->manager->getAdminSections());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetAdminSectionsEmptySection() {
|
||||||
|
$this->l10n
|
||||||
|
->expects($this->any())
|
||||||
|
->method('t')
|
||||||
|
->will($this->returnArgument(0));
|
||||||
|
|
||||||
|
$this->mapper->expects($this->once())
|
||||||
|
->method('getAdminSectionsFromDB')
|
||||||
|
->will($this->returnValue([
|
||||||
|
['class' => '\OCA\LogReader\Settings\Section', 'priority' => 90]
|
||||||
|
]));
|
||||||
|
|
||||||
|
$this->mapper->expects($this->once())
|
||||||
|
->method('getAdminSettingsCountFromDB')
|
||||||
|
->will($this->returnValue([]));
|
||||||
|
|
||||||
$this->assertEquals([
|
$this->assertEquals([
|
||||||
0 => [new Section('server', 'Server settings', 0)],
|
0 => [new Section('server', 'Server settings', 0)],
|
||||||
5 => [new Section('sharing', 'Sharing', 0)],
|
5 => [new Section('sharing', 'Sharing', 0)],
|
||||||
|
@ -183,47 +178,9 @@ class ManagerTest extends TestCase {
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testGetAdminSettings() {
|
public function testGetAdminSettings() {
|
||||||
$qb = $this->getMockBuilder('\OCP\DB\QueryBuilder\IQueryBuilder')->getMock();
|
$this->mapper->expects($this->any())
|
||||||
$qb
|
->method('getAdminSettingsFromDB')
|
||||||
->expects($this->once())
|
->will($this->returnValue([]));
|
||||||
->method('select')
|
|
||||||
->with(['class', 'priority'])
|
|
||||||
->willReturn($qb);
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('from')
|
|
||||||
->with('admin_settings')
|
|
||||||
->willReturn($qb);
|
|
||||||
$expressionBuilder = $this->getMockBuilder('\OCP\DB\QueryBuilder\IExpressionBuilder')->getMock();
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('expr')
|
|
||||||
->willReturn($expressionBuilder);
|
|
||||||
$param = $this->getMockBuilder('\OCP\DB\QueryBuilder\IParameter')->getMock();
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('createParameter')
|
|
||||||
->with('section')
|
|
||||||
->willReturn($param);
|
|
||||||
$expressionBuilder
|
|
||||||
->expects($this->once())
|
|
||||||
->method('eq')
|
|
||||||
->with('section', $param)
|
|
||||||
->willReturn('myString');
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('where')
|
|
||||||
->with('myString')
|
|
||||||
->willReturn($qb);
|
|
||||||
$stmt = $this->getMockBuilder('\Doctrine\DBAL\Driver\Statement')->getMock();
|
|
||||||
$qb
|
|
||||||
->expects($this->once())
|
|
||||||
->method('execute')
|
|
||||||
->willReturn($stmt);
|
|
||||||
$this->dbConnection
|
|
||||||
->expects($this->exactly(2))
|
|
||||||
->method('getQueryBuilder')
|
|
||||||
->willReturn($qb);
|
|
||||||
|
|
||||||
$this->assertEquals([
|
$this->assertEquals([
|
||||||
0 => [new Sharing($this->config)],
|
0 => [new Sharing($this->config)],
|
||||||
|
|
|
@ -0,0 +1,139 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (c) 2016 Robin Appelman <robin@icewind.nl>
|
||||||
|
*
|
||||||
|
* @author Robin Appelman <robin@icewind.nl>
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* 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
|
||||||
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Tests\Settings;
|
||||||
|
|
||||||
|
use OC\DB\QueryBuilder\Literal;
|
||||||
|
use OC\Settings\Mapper;
|
||||||
|
use Test\TestCase;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @group DB
|
||||||
|
*/
|
||||||
|
class MapperTest extends TestCase {
|
||||||
|
const SECTION_PREFIX = 'test_section_';
|
||||||
|
|
||||||
|
/** @var Mapper */
|
||||||
|
private $mapper;
|
||||||
|
|
||||||
|
public function setUp() {
|
||||||
|
parent::setUp();
|
||||||
|
$this->mapper = new Mapper(\OC::$server->getDatabaseConnection());
|
||||||
|
}
|
||||||
|
|
||||||
|
public function tearDown() {
|
||||||
|
parent::tearDown();
|
||||||
|
|
||||||
|
$db = \OC::$server->getDatabaseConnection();
|
||||||
|
$builder = $db->getQueryBuilder();
|
||||||
|
|
||||||
|
$builder->delete(Mapper::TABLE_ADMIN_SECTIONS)
|
||||||
|
->where($builder->expr()->like('id', new Literal(self::SECTION_PREFIX . '%')));
|
||||||
|
|
||||||
|
$builder->delete(Mapper::TABLE_ADMIN_SETTINGS)
|
||||||
|
->where($builder->expr()->like('section', new Literal(self::SECTION_PREFIX . '%')));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testManipulateSettings() {
|
||||||
|
$this->assertEquals(false, $this->mapper->has(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy'));
|
||||||
|
$this->assertNotContains('\OC\Dummy', $this->mapper->getClasses(Mapper::TABLE_ADMIN_SETTINGS));
|
||||||
|
|
||||||
|
$this->mapper->add(Mapper::TABLE_ADMIN_SETTINGS, [
|
||||||
|
'class' => '\OC\Dummy',
|
||||||
|
'section' => self::SECTION_PREFIX . '1',
|
||||||
|
'priority' => 5
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->assertEquals(true, $this->mapper->has(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy'));
|
||||||
|
|
||||||
|
$this->assertContains('\OC\Dummy', $this->mapper->getClasses(Mapper::TABLE_ADMIN_SETTINGS));
|
||||||
|
|
||||||
|
$rows = $this->mapper->getAdminSettingsFromDB(self::SECTION_PREFIX . '1');
|
||||||
|
$this->assertEquals([
|
||||||
|
['class' => '\OC\Dummy', 'priority' => 5]
|
||||||
|
], $rows);
|
||||||
|
|
||||||
|
$this->mapper->update(Mapper::TABLE_ADMIN_SETTINGS, 'class', '\OC\Dummy', [
|
||||||
|
'section' => self::SECTION_PREFIX . '1', 'priority' => 15
|
||||||
|
]);
|
||||||
|
|
||||||
|
$rows = $this->mapper->getAdminSettingsFromDB(self::SECTION_PREFIX . '1');
|
||||||
|
$this->assertEquals([
|
||||||
|
['class' => '\OC\Dummy', 'priority' => 15]
|
||||||
|
], $rows);
|
||||||
|
|
||||||
|
$this->mapper->update(Mapper::TABLE_ADMIN_SETTINGS, 'class', '\OC\Dummy', [
|
||||||
|
'section' => self::SECTION_PREFIX . '2', 'priority' => 15
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->assertEquals([], $this->mapper->getAdminSettingsFromDB(self::SECTION_PREFIX . '1'));
|
||||||
|
$rows = $this->mapper->getAdminSettingsFromDB(self::SECTION_PREFIX . '2');
|
||||||
|
$this->assertEquals([
|
||||||
|
['class' => '\OC\Dummy', 'priority' => 15]
|
||||||
|
], $rows);
|
||||||
|
|
||||||
|
$this->mapper->remove(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy');
|
||||||
|
|
||||||
|
$this->assertEquals(false, $this->mapper->has(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy'));
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testGetAdminSections() {
|
||||||
|
$this->assertFalse($this->mapper->has(Mapper::TABLE_ADMIN_SECTIONS, '\OC\Dummy'));
|
||||||
|
|
||||||
|
$this->mapper->add(Mapper::TABLE_ADMIN_SECTIONS, [
|
||||||
|
'id' => self::SECTION_PREFIX . '1',
|
||||||
|
'class' => '\OC\Dummy',
|
||||||
|
'priority' => 1,
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->assertTrue($this->mapper->has(Mapper::TABLE_ADMIN_SECTIONS, '\OC\Dummy'));
|
||||||
|
|
||||||
|
// until we add a setting for the section it's not returned
|
||||||
|
$this->assertNotContains([
|
||||||
|
'class' => '\OC\Dummy',
|
||||||
|
'priority' => 1,
|
||||||
|
], $this->mapper->getAdminSectionsFromDB());
|
||||||
|
|
||||||
|
$this->mapper->add(Mapper::TABLE_ADMIN_SETTINGS, [
|
||||||
|
'class' => '\OC\Dummy',
|
||||||
|
'section' => self::SECTION_PREFIX . '1',
|
||||||
|
'priority' => 5
|
||||||
|
]);
|
||||||
|
|
||||||
|
$this->assertContains([
|
||||||
|
'class' => '\OC\Dummy',
|
||||||
|
'priority' => 1,
|
||||||
|
], $this->mapper->getAdminSectionsFromDB());
|
||||||
|
|
||||||
|
$this->mapper->remove(Mapper::TABLE_ADMIN_SETTINGS, '\OC\Dummy');
|
||||||
|
|
||||||
|
$this->assertNotContains([
|
||||||
|
'class' => '\OC\Dummy',
|
||||||
|
'priority' => 1,
|
||||||
|
], $this->mapper->getAdminSectionsFromDB());
|
||||||
|
|
||||||
|
$this->mapper->remove(Mapper::TABLE_ADMIN_SECTIONS, '\OC\Dummy');
|
||||||
|
|
||||||
|
$this->assertFalse($this->mapper->has(Mapper::TABLE_ADMIN_SECTIONS, '\OC\Dummy'));
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue