Blame view
sources/lib/private/group.php
7.84 KB
|
03e52840d
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 |
<?php
/**
* ownCloud
*
* @author Frank Karlitschek
* @copyright 2012 Frank Karlitschek frank@owncloud.org
*
* 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/>.
*
*/
/**
* This class provides all methods needed for managing groups.
*
* Hooks provided:
* pre_createGroup(&run, gid)
* post_createGroup(gid)
* pre_deleteGroup(&run, gid)
* post_deleteGroup(gid)
* pre_addToGroup(&run, uid, gid)
* post_addToGroup(uid, gid)
* pre_removeFromGroup(&run, uid, gid)
* post_removeFromGroup(uid, gid)
*/
class OC_Group {
|
|
03e52840d
|
37 |
/** |
|
31b7f2792
|
38 |
* @var \OC\Group\Manager $manager |
|
03e52840d
|
39 |
*/ |
|
31b7f2792
|
40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 |
private static $manager;
/**
* @var \OC\User\Manager
*/
private static $userManager;
/**
* @return \OC\Group\Manager
*/
public static function getManager() {
if (self::$manager) {
return self::$manager;
}
self::$userManager = \OC_User::getManager();
self::$manager = new \OC\Group\Manager(self::$userManager);
return self::$manager;
}
|
|
03e52840d
|
58 59 60 |
/** * @brief set the group backend |
|
31b7f2792
|
61 |
* @param \OC_Group_Backend $backend The backend to use for user managment |
|
03e52840d
|
62 63 |
* @return bool */ |
|
31b7f2792
|
64 65 66 |
public static function useBackend($backend) {
self::getManager()->addBackend($backend);
return true;
|
|
03e52840d
|
67 68 69 70 71 72 |
}
/**
* remove all used backends
*/
public static function clearBackends() {
|
|
31b7f2792
|
73 |
self::getManager()->clearBackends(); |
|
03e52840d
|
74 75 76 77 78 79 80 81 82 83 |
} /** * @brief Try to create a new group * @param string $gid The name of the group to create * @return bool * * Tries to create a new group. If the group name already exists, false will * be returned. Basic checking of Group name */ |
|
31b7f2792
|
84 85 |
public static function createGroup($gid) {
OC_Hook::emit("OC_Group", "pre_createGroup", array("run" => true, "gid" => $gid));
|
|
03e52840d
|
86 |
|
|
31b7f2792
|
87 88 89 90 |
if (self::getManager()->createGroup($gid)) {
OC_Hook::emit("OC_User", "post_createGroup", array("gid" => $gid));
return true;
} else {
|
|
03e52840d
|
91 92 93 94 95 96 97 98 99 100 101 |
return false; } } /** * @brief delete a group * @param string $gid gid of the group to delete * @return bool * * Deletes a group and removes it from the group_user-table */ |
|
31b7f2792
|
102 |
public static function deleteGroup($gid) {
|
|
03e52840d
|
103 |
// Prevent users from deleting group admin |
|
31b7f2792
|
104 |
if ($gid == "admin") {
|
|
03e52840d
|
105 106 |
return false; } |
|
31b7f2792
|
107 |
OC_Hook::emit("OC_Group", "pre_deleteGroup", array("run" => true, "gid" => $gid));
|
|
03e52840d
|
108 |
|
|
31b7f2792
|
109 110 111 112 |
$group = self::getManager()->get($gid);
if ($group) {
if ($group->delete()) {
OC_Hook::emit("OC_User", "post_deleteGroup", array("gid" => $gid));
|
|
03e52840d
|
113 114 |
return true; } |
|
03e52840d
|
115 |
} |
|
31b7f2792
|
116 |
return false; |
|
03e52840d
|
117 118 119 120 121 122 123 124 125 126 |
} /** * @brief is user in group? * @param string $uid uid of the user * @param string $gid gid of the group * @return bool * * Checks whether the user is member of a group or not. */ |
|
31b7f2792
|
127 128 129 130 131 |
public static function inGroup($uid, $gid) {
$group = self::getManager()->get($gid);
$user = self::$userManager->get($uid);
if ($group and $user) {
return $group->inGroup($user);
|
|
03e52840d
|
132 133 134 135 136 137 138 139 140 141 142 143 |
} return false; } /** * @brief Add a user to a group * @param string $uid Name of the user to add to group * @param string $gid Name of the group in which add the user * @return bool * * Adds a user to a group. */ |
|
31b7f2792
|
144 145 146 147 148 149 150 151 152 |
public static function addToGroup($uid, $gid) {
$group = self::getManager()->get($gid);
$user = self::$userManager->get($uid);
if ($group and $user) {
OC_Hook::emit("OC_Group", "pre_addToGroup", array("run" => true, "uid" => $uid, "gid" => $gid));
$group->addUser($user);
OC_Hook::emit("OC_User", "post_addToGroup", array("uid" => $uid, "gid" => $gid));
return true;
} else {
|
|
03e52840d
|
153 154 155 156 157 158 159 160 161 162 163 164 |
return false; } } /** * @brief Removes a user from a group * @param string $uid Name of the user to remove from group * @param string $gid Name of the group from which remove the user * @return bool * * removes the user from a group. */ |
|
31b7f2792
|
165 166 167 168 169 170 171 |
public static function removeFromGroup($uid, $gid) {
$group = self::getManager()->get($gid);
$user = self::$userManager->get($uid);
if ($group and $user) {
OC_Hook::emit("OC_Group", "pre_removeFromGroup", array("run" => true, "uid" => $uid, "gid" => $gid));
$group->removeUser($user);
OC_Hook::emit("OC_User", "post_removeFromGroup", array("uid" => $uid, "gid" => $gid));
|
|
03e52840d
|
172 |
return true; |
|
31b7f2792
|
173 |
} else {
|
|
03e52840d
|
174 175 176 177 178 179 180 181 182 183 184 185 |
return false; } } /** * @brief Get all groups a user belongs to * @param string $uid Name of the user * @return array with group names * * This function fetches all groups a user belongs to. It does not check * if the user exists at all. */ |
|
31b7f2792
|
186 187 188 189 190 191 192 193 194 195 196 |
public static function getUserGroups($uid) {
$user = self::$userManager->get($uid);
if ($user) {
$groups = self::getManager()->getUserGroups($user);
$groupIds = array();
foreach ($groups as $group) {
$groupIds[] = $group->getGID();
}
return $groupIds;
} else {
return array();
|
|
03e52840d
|
197 |
} |
|
03e52840d
|
198 199 200 201 202 203 204 205 |
} /** * @brief get a list of all groups * @returns array with group names * * Returns a list with all groups */ |
|
31b7f2792
|
206 207 208 209 210 |
public static function getGroups($search = '', $limit = null, $offset = null) {
$groups = self::getManager()->search($search, $limit, $offset);
$groupIds = array();
foreach ($groups as $group) {
$groupIds[] = $group->getGID();
|
|
03e52840d
|
211 |
} |
|
31b7f2792
|
212 |
return $groupIds; |
|
03e52840d
|
213 214 215 216 |
} /** * check if a group exists |
|
31b7f2792
|
217 |
* |
|
03e52840d
|
218 219 220 221 |
* @param string $gid
* @return bool
*/
public static function groupExists($gid) {
|
|
31b7f2792
|
222 |
return self::getManager()->groupExists($gid); |
|
03e52840d
|
223 224 225 226 227 228 229 |
}
/**
* @brief get a list of all users in a group
* @returns array with user ids
*/
public static function usersInGroup($gid, $search = '', $limit = -1, $offset = 0) {
|
|
31b7f2792
|
230 231 232 233 234 235 236 237 238 239 |
$group = self::getManager()->get($gid);
if ($group) {
$users = $group->searchUsers($search, $limit, $offset);
$userIds = array();
foreach ($users as $user) {
$userIds[] = $user->getUID();
}
return $userIds;
} else {
return array();
|
|
03e52840d
|
240 |
} |
|
03e52840d
|
241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 |
}
/**
* @brief get a list of all users in several groups
* @param array $gids
* @param string $search
* @param int $limit
* @param int $offset
* @return array with user ids
*/
public static function usersInGroups($gids, $search = '', $limit = -1, $offset = 0) {
$users = array();
foreach ($gids as $gid) {
// TODO Need to apply limits to groups as total
$users = array_merge(array_diff(self::usersInGroup($gid, $search, $limit, $offset), $users), $users);
}
return $users;
}
/**
* @brief get a list of all display names in a group
* @returns array with display names (value) and user ids(key)
*/
public static function displayNamesInGroup($gid, $search = '', $limit = -1, $offset = 0) {
|
|
31b7f2792
|
265 266 267 268 269 270 |
$group = self::getManager()->get($gid);
if ($group) {
$users = $group->searchDisplayName($search, $limit, $offset);
$displayNames = array();
foreach ($users as $user) {
$displayNames[$user->getUID()] = $user->getDisplayName();
|
|
03e52840d
|
271 |
} |
|
31b7f2792
|
272 273 274 |
return $displayNames;
} else {
return array();
|
|
03e52840d
|
275 |
} |
|
03e52840d
|
276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 |
}
/**
* @brief get a list of all display names in several groups
* @param array $gids
* @param string $search
* @param int $limit
* @param int $offset
* @return array with display names (Key) user ids (value)
*/
public static function displayNamesInGroups($gids, $search = '', $limit = -1, $offset = 0) {
$displayNames = array();
foreach ($gids as $gid) {
// TODO Need to apply limits to groups as total
$diff = array_diff(
self::displayNamesInGroup($gid, $search, $limit, $offset),
$displayNames
);
if ($diff) {
$displayNames = array_merge($diff, $displayNames);
}
}
return $displayNames;
}
}
|