Blame view
sources/lib/private/group.php
7.72 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 |
/** |
|
6d9380f96
|
60 61 |
* set the group backend * @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 |
} /** |
|
6d9380f96
|
77 |
* Try to create a new group |
|
03e52840d
|
78 79 80 81 82 83 |
* @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 |
return false; } } /** |
|
6d9380f96
|
96 |
* delete a group |
|
03e52840d
|
97 98 99 100 101 |
* @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 |
} /** |
|
6d9380f96
|
120 |
* is user in group? |
|
03e52840d
|
121 122 123 124 125 126 |
* @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 |
} return false; } /** |
|
6d9380f96
|
137 |
* Add a user to a group |
|
03e52840d
|
138 139 140 141 142 143 |
* @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 |
return false; } } /** |
|
6d9380f96
|
158 |
* Removes a user from a group |
|
03e52840d
|
159 160 161 162 163 164 |
* @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 |
return false; } } /** |
|
6d9380f96
|
179 |
* Get all groups a user belongs to |
|
03e52840d
|
180 |
* @param string $uid Name of the user |
|
6d9380f96
|
181 |
* @return array an array of group names |
|
03e52840d
|
182 183 184 185 |
* * This function fetches all groups a user belongs to. It does not check * if the user exists at all. */ |
|
31b7f2792
|
186 187 188 |
public static function getUserGroups($uid) {
$user = self::$userManager->get($uid);
if ($user) {
|
|
6d9380f96
|
189 |
return self::getManager()->getUserGroupIds($user); |
|
31b7f2792
|
190 191 |
} else {
return array();
|
|
03e52840d
|
192 |
} |
|
03e52840d
|
193 194 195 |
} /** |
|
6d9380f96
|
196 197 198 199 200 |
* get a list of all groups * @param string $search * @param int|null $limit * @param int|null $offset * @return array an array of group names |
|
03e52840d
|
201 202 203 |
* * Returns a list with all groups */ |
|
31b7f2792
|
204 205 206 207 208 |
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
|
209 |
} |
|
31b7f2792
|
210 |
return $groupIds; |
|
03e52840d
|
211 212 213 214 |
} /** * check if a group exists |
|
31b7f2792
|
215 |
* |
|
03e52840d
|
216 217 218 219 |
* @param string $gid
* @return bool
*/
public static function groupExists($gid) {
|
|
31b7f2792
|
220 |
return self::getManager()->groupExists($gid); |
|
03e52840d
|
221 222 223 |
} /** |
|
6d9380f96
|
224 225 226 227 228 229 |
* get a list of all users in a group * @param string $gid * @param string $search * @param int $limit * @param int $offset * @return array an array of user ids |
|
03e52840d
|
230 231 |
*/
public static function usersInGroup($gid, $search = '', $limit = -1, $offset = 0) {
|
|
31b7f2792
|
232 233 234 235 236 237 238 239 240 241 |
$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
|
242 |
} |
|
03e52840d
|
243 244 245 |
} /** |
|
6d9380f96
|
246 247 |
* get a list of all users in several groups * @param string[] $gids |
|
03e52840d
|
248 249 250 |
* @param string $search * @param int $limit * @param int $offset |
|
6d9380f96
|
251 |
* @return array an array of user ids |
|
03e52840d
|
252 253 254 255 256 257 258 259 260 261 262 |
*/
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;
}
/**
|
|
6d9380f96
|
263 264 265 266 267 268 |
* get a list of all display names in a group * @param string $gid * @param string $search * @param int $limit * @param int $offset * @return array an array of display names (value) and user ids(key) |
|
03e52840d
|
269 270 |
*/
public static function displayNamesInGroup($gid, $search = '', $limit = -1, $offset = 0) {
|
|
837968727
|
271 |
return self::getManager()->displayNamesInGroup($gid, $search, $limit, $offset); |
|
03e52840d
|
272 273 274 |
} /** |
|
6d9380f96
|
275 |
* get a list of all display names in several groups |
|
03e52840d
|
276 277 278 279 |
* @param array $gids * @param string $search * @param int $limit * @param int $offset |
|
6d9380f96
|
280 |
* @return array an array of display names (Key) user ids (value) |
|
03e52840d
|
281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 |
*/
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;
}
}
|