summaryrefslogtreecommitdiffstats
path: root/lib/private
diff options
context:
space:
mode:
authorJoas Schilling <213943+nickvergessen@users.noreply.github.com>2018-03-27 16:10:26 +0200
committerGitHub <noreply@github.com>2018-03-27 16:10:26 +0200
commit709589f2dbe3ce49f3bd71e1531e723353ee631d (patch)
treeca09d702d27a87eda6be628774814c3e4d00b748 /lib/private
parent41215c9d78210c0b66ca292f66766226cc2ab8ad (diff)
parentb98c218201b3db952d3ecceed5271000aaf27859 (diff)
downloadnextcloud-server-709589f2dbe3ce49f3bd71e1531e723353ee631d.tar.gz
nextcloud-server-709589f2dbe3ce49f3bd71e1531e723353ee631d.zip
Merge pull request #8780 from nextcloud/bugfix/noid/query-builder-database-backends
Move the group database backend fully to query builder
Diffstat (limited to 'lib/private')
-rw-r--r--lib/private/Group/Database.php91
1 files changed, 59 insertions, 32 deletions
diff --git a/lib/private/Group/Database.php b/lib/private/Group/Database.php
index a439a978cce..abd7f6ee6ee 100644
--- a/lib/private/Group/Database.php
+++ b/lib/private/Group/Database.php
@@ -40,23 +40,25 @@
namespace OC\Group;
+use OCP\IDBConnection;
+
/**
* Class for group management in a SQL Database (e.g. MySQL, SQLite)
*/
-class Database extends \OC\Group\Backend {
+class Database extends Backend {
/** @var string[] */
private $groupCache = [];
- /** @var \OCP\IDBConnection */
+ /** @var IDBConnection */
private $dbConn;
/**
* \OC\Group\Database constructor.
*
- * @param \OCP\IDBConnection|null $dbConn
+ * @param IDBConnection|null $dbConn
*/
- public function __construct(\OCP\IDBConnection $dbConn = null) {
+ public function __construct(IDBConnection $dbConn = null) {
$this->dbConn = $dbConn;
}
@@ -219,7 +221,7 @@ class Database extends \OC\Group\Backend {
$groups = [];
while( $row = $cursor->fetch()) {
- $groups[] = $row["gid"];
+ $groups[] = $row['gid'];
$this->groupCache[$row['gid']] = $row['gid'];
}
$cursor->closeCursor();
@@ -237,19 +239,29 @@ class Database extends \OC\Group\Backend {
* Returns a list with all groups
*/
public function getGroups($search = '', $limit = null, $offset = null) {
- $parameters = [];
- $searchLike = '';
+ $this->fixDI();
+
+ $query = $this->dbConn->getQueryBuilder();
+ $query->select('gid')
+ ->from('groups')
+ ->orderBy('gid', 'ASC');
+
if ($search !== '') {
- $parameters[] = '%' . $search . '%';
- $searchLike = ' WHERE LOWER(`gid`) LIKE LOWER(?)';
+ $query->where($query->expr()->iLike('gid', $query->createNamedParameter(
+ '%' . $this->dbConn->escapeLikeParameter($search) . '%'
+ )));
}
- $stmt = \OC_DB::prepare('SELECT `gid` FROM `*PREFIX*groups`' . $searchLike . ' ORDER BY `gid` ASC', $limit, $offset);
- $result = $stmt->execute($parameters);
- $groups = array();
- while ($row = $result->fetchRow()) {
+ $query->setMaxResults($limit)
+ ->setFirstResult($offset);
+ $result = $query->execute();
+
+ $groups = [];
+ while ($row = $result->fetch()) {
$groups[] = $row['gid'];
}
+ $result->closeCursor();
+
return $groups;
}
@@ -290,21 +302,30 @@ class Database extends \OC\Group\Backend {
* @return array an array of user ids
*/
public function usersInGroup($gid, $search = '', $limit = null, $offset = null) {
- $parameters = [$gid];
- $searchLike = '';
+ $this->fixDI();
+
+ $query = $this->dbConn->getQueryBuilder();
+ $query->select('uid')
+ ->from('group_user')
+ ->where($query->expr()->eq('gid', $query->createNamedParameter($gid)))
+ ->orderBy('uid', 'ASC');
+
if ($search !== '') {
- $parameters[] = '%' . $this->dbConn->escapeLikeParameter($search) . '%';
- $searchLike = ' AND `uid` LIKE ?';
+ $query->andWhere($query->expr()->like('uid', $query->createNamedParameter(
+ '%' . $this->dbConn->escapeLikeParameter($search) . '%'
+ )));
}
- $stmt = \OC_DB::prepare('SELECT `uid` FROM `*PREFIX*group_user` WHERE `gid` = ?' . $searchLike . ' ORDER BY `uid` ASC',
- $limit,
- $offset);
- $result = $stmt->execute($parameters);
- $users = array();
- while ($row = $result->fetchRow()) {
+ $query->setMaxResults($limit)
+ ->setFirstResult($offset);
+ $result = $query->execute();
+
+ $users = [];
+ while ($row = $result->fetch()) {
$users[] = $row['uid'];
}
+ $result->closeCursor();
+
return $users;
}
@@ -313,20 +334,26 @@ class Database extends \OC\Group\Backend {
* @param string $gid
* @param string $search
* @return int|false
- * @throws \OC\DatabaseException
*/
public function countUsersInGroup($gid, $search = '') {
- $parameters = [$gid];
- $searchLike = '';
+ $this->fixDI();
+
+ $query = $this->dbConn->getQueryBuilder();
+ $query->selectAlias($query->createFunction('COUNT(*)'), 'num_users')
+ ->from('group_user')
+ ->where($query->expr()->eq('gid', $query->createNamedParameter($gid)));
+
if ($search !== '') {
- $parameters[] = '%' . $this->dbConn->escapeLikeParameter($search) . '%';
- $searchLike = ' AND `uid` LIKE ?';
+ $query->andWhere($query->expr()->like('uid', $query->createNamedParameter(
+ '%' . $this->dbConn->escapeLikeParameter($search) . '%'
+ )));
}
- $stmt = \OC_DB::prepare('SELECT COUNT(`uid`) AS `count` FROM `*PREFIX*group_user` WHERE `gid` = ?' . $searchLike);
- $result = $stmt->execute($parameters);
- $count = $result->fetchOne();
- if($count !== false) {
+ $result = $query->execute();
+ $count = $result->fetchColumn();
+ $result->closeCursor();
+
+ if ($count !== false) {
$count = (int)$count;
}
return $count;