summaryrefslogtreecommitdiffstats
path: root/apps/user_ldap/group_ldap.php
diff options
context:
space:
mode:
authorArthur Schiwon <blizzz@owncloud.com>2012-04-14 18:05:29 +0200
committerArthur Schiwon <blizzz@owncloud.com>2012-04-14 18:08:40 +0200
commit61a43419a5fae6c44fe26c631ce8256966893e9e (patch)
tree5581fb37409caa6dba275147fa1320448279d5ec /apps/user_ldap/group_ldap.php
parentdec139716e7f93d25a7064ff03b2b68a51e3ebff (diff)
downloadnextcloud-server-61a43419a5fae6c44fe26c631ce8256966893e9e.tar.gz
nextcloud-server-61a43419a5fae6c44fe26c631ce8256966893e9e.zip
starting to create the ldap group backend (with some inspiration from Yoann Gini) and preparing an general LDAP class
Diffstat (limited to 'apps/user_ldap/group_ldap.php')
-rw-r--r--apps/user_ldap/group_ldap.php79
1 files changed, 79 insertions, 0 deletions
diff --git a/apps/user_ldap/group_ldap.php b/apps/user_ldap/group_ldap.php
new file mode 100644
index 00000000000..a55c9064864
--- /dev/null
+++ b/apps/user_ldap/group_ldap.php
@@ -0,0 +1,79 @@
+<?php
+
+/**
+ * ownCloud – LDAP group backend
+ *
+ * @author Arthur Schiwon
+ * @copyright 2012 Arthur Schiwon blizzz@owncloud.com
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU AFFERO GENERAL PUBLIC LICENSE
+ * License as published by the Free Software Foundation; either
+ * version 3 of the License, or any later version.
+ *
+ * This library 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 library. If not, see <http://www.gnu.org/licenses/>.
+ *
+ */
+
+ class OC_GROUP_LDAP extends OC_Group_Backend {
+// //group specific settings
+ protected $ldapGroupFilter;
+ protected $ldapGroupDisplayName;
+
+ public function __construct() {
+ $this->ldapGroupFilter = OC_Appconfig::getValue('user_ldap', 'ldap_group_filter', '(objectClass=posixGroup)');
+ $this->ldapGroupDisplayName = OC_Appconfig::getValue('user_ldap', 'ldap_group_display_name', 'cn');
+ }
+
+ /**
+ * @brief is user in group?
+ * @param $uid uid of the user
+ * @param $gid gid of the group
+ * @returns true/false
+ *
+ * Checks whether the user is member of a group or not.
+ */
+ public function inGroup($uid, $gid) {
+ }
+
+ /**
+ * @brief Get all groups a user belongs to
+ * @param $uid Name of the user
+ * @returns array with group names
+ *
+ * This function fetches all groups a user belongs to. It does not check
+ * if the user exists at all.
+ */
+ public function getUserGroups($uid) {
+ }
+
+ /**
+ * @brief get a list of all users in a group
+ * @returns array with user ids
+ */
+ public function getUsersInGroup($gid) {
+ }
+
+ /**
+ * @brief get a list of all groups
+ * @returns array with group names
+ *
+ * Returns a list with all groups
+ */
+ public function getGroups() {
+ $groups = OC_LDAP::search($this->ldapGroupFilter, $this->ldapGroupDisplayName);
+
+ if(count($groups) == 0 )
+ return array();
+ else {
+ return array_unique($groups, SORT_LOCALE_STRING);
+ }
+ }
+
+ } \ No newline at end of file