summaryrefslogtreecommitdiffstats
path: root/apps/user_ldap/group_ldap.php
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@owncloud.com>2012-06-01 13:49:11 +0200
committerArthur Schiwon <blizzz@owncloud.com>2012-06-01 13:49:11 +0200
commita4f177d75d28649af21bc33975259e6d19cae634 (patch)
treec4990f26dfd232c33b8cb442d5e24ab12a2a7ebe /apps/user_ldap/group_ldap.php
parent75d56f24f23efbafb9cc5c8f779ba020e0bb3c51 (diff)
downloadnextcloud-server-a4f177d75d28649af21bc33975259e6d19cae634.tar.gz
nextcloud-server-a4f177d75d28649af21bc33975259e6d19cae634.zip
LDAP group backend: If a group filter is not configured, do not do anything. Fixes oc-867
Diffstat (limited to 'apps/user_ldap/group_ldap.php')
-rw-r--r--apps/user_ldap/group_ldap.php19
1 files changed, 19 insertions, 0 deletions
diff --git a/apps/user_ldap/group_ldap.php b/apps/user_ldap/group_ldap.php
index b3ff6c53881..2c16bf312f8 100644
--- a/apps/user_ldap/group_ldap.php
+++ b/apps/user_ldap/group_ldap.php
@@ -25,10 +25,15 @@ class OC_GROUP_LDAP extends OC_Group_Backend {
// //group specific settings
protected $ldapGroupFilter;
protected $ldapGroupMemberAssocAttr;
+ protected $configured = false;
public function __construct() {
$this->ldapGroupFilter = OCP\Config::getAppValue('user_ldap', 'ldap_group_filter', '(objectClass=posixGroup)');
$this->ldapGroupMemberAssocAttr = OCP\Config::getAppValue('user_ldap', 'ldap_group_member_assoc_attribute', 'uniqueMember');
+
+ if(empty($this->ldapGroupFilter) || empty($this->ldapGroupMemberAssocAttr)) {
+ $this->configured = false;
+ }
}
/**
@@ -40,6 +45,9 @@ class OC_GROUP_LDAP extends OC_Group_Backend {
* Checks whether the user is member of a group or not.
*/
public function inGroup($uid, $gid) {
+ if(!$this->configured) {
+ return false;
+ }
$dn_user = OC_LDAP::username2dn($uid);
$dn_group = OC_LDAP::groupname2dn($gid);
// just in case
@@ -79,6 +87,9 @@ class OC_GROUP_LDAP extends OC_Group_Backend {
* if the user exists at all.
*/
public function getUserGroups($uid) {
+ if(!$this->configured) {
+ return array();
+ }
$userDN = OC_LDAP::username2dn($uid);
if(!$userDN) {
return array();
@@ -111,6 +122,10 @@ class OC_GROUP_LDAP extends OC_Group_Backend {
* @returns array with user ids
*/
public function usersInGroup($gid) {
+ if(!$this->configured) {
+ return array();
+ }
+
$groupDN = OC_LDAP::groupname2dn($gid);
if(!$groupDN) {
return array();
@@ -149,6 +164,10 @@ class OC_GROUP_LDAP extends OC_Group_Backend {
* Returns a list with all groups
*/
public function getGroups() {
+ if(!$this->configured) {
+ return array();
+ }
+
$ldap_groups = OC_LDAP::fetchListOfGroups($this->ldapGroupFilter, array(OC_LDAP::conf('ldapGroupDisplayName'), 'dn'));
$groups = OC_LDAP::ownCloudGroupNames($ldap_groups);
return $groups;