diff options
author | Joas Schilling <coding@schilljs.com> | 2019-09-20 11:04:36 +0200 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2019-09-27 14:29:56 +0200 |
commit | 45506adc5c2a34a8c812a2a3c9273a8447b450af (patch) | |
tree | adc63ec1a19b2351eac77962010999c5029c9fc4 /lib/private/Group | |
parent | 88b6dc5eaf28b1bfe72a62773e8a9ce339979ea3 (diff) | |
download | nextcloud-server-45506adc5c2a34a8c812a2a3c9273a8447b450af.tar.gz nextcloud-server-45506adc5c2a34a8c812a2a3c9273a8447b450af.zip |
Add a displayname to the database group backend
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'lib/private/Group')
-rw-r--r-- | lib/private/Group/Database.php | 42 |
1 files changed, 39 insertions, 3 deletions
diff --git a/lib/private/Group/Database.php b/lib/private/Group/Database.php index 7a5728b957d..5e39398c60d 100644 --- a/lib/private/Group/Database.php +++ b/lib/private/Group/Database.php @@ -49,6 +49,8 @@ use OCP\Group\Backend\ICountDisabledInGroup; use OCP\Group\Backend\ICountUsersBackend; use OCP\Group\Backend\ICreateGroupBackend; use OCP\Group\Backend\IDeleteGroupBackend; +use OCP\Group\Backend\IGetDisplayNameBackend; +use OCP\Group\Backend\IGroupDetailsBackend; use OCP\Group\Backend\IRemoveFromGroupBackend; use OCP\IDBConnection; @@ -61,6 +63,8 @@ class Database extends ABackend ICountUsersBackend, ICreateGroupBackend, IDeleteGroupBackend, + IGetDisplayNameBackend, + IGroupDetailsBackend, IRemoveFromGroupBackend { /** @var string[] */ @@ -391,7 +395,7 @@ class Database extends ABackend */ public function countDisabledInGroup(string $gid): int { $this->fixDI(); - + $query = $this->dbConn->getQueryBuilder(); $query->select($query->createFunction('COUNT(DISTINCT ' . $query->getColumnName('uid') . ')')) ->from('preferences', 'p') @@ -400,11 +404,11 @@ class Database extends ABackend ->andWhere($query->expr()->eq('configkey', $query->createNamedParameter('enabled'))) ->andWhere($query->expr()->eq('configvalue', $query->createNamedParameter('false'), IQueryBuilder::PARAM_STR)) ->andWhere($query->expr()->eq('gid', $query->createNamedParameter($gid), IQueryBuilder::PARAM_STR)); - + $result = $query->execute(); $count = $result->fetchColumn(); $result->closeCursor(); - + if ($count !== false) { $count = (int)$count; } else { @@ -414,4 +418,36 @@ class Database extends ABackend return $count; } + /** + * @param string $gid + * @return string + * @since 17.0.0 + */ + public function getDisplayName(string $gid): string { + $query = $this->dbConn->getQueryBuilder(); + $query->select('displayname') + ->from('groups') + ->where($query->expr()->eq('gid', $query->createNamedParameter($gid))); + + $result = $query->execute(); + $displayName = $result->fetchColumn(); + $result->closeCursor(); + + return (string) $displayName; + } + + /** + * @param string $gid + * @return array + * @since 14.0.0 + */ + public function getGroupDetails(string $gid): array { + $displayName = $this->getDisplayName($gid); + if ($displayName !== '') { + return ['displayName' => $displayName]; + } + + return []; + } + } |