Blame view
sources/lib/private/subadmin.php
5.17 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 |
<?php
/**
* ownCloud
*
* @author Georg Ehrke
* @copyright 2012 Georg Ehrke
*
* 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/>.
*
*/
OC_Hook::connect('OC_User', 'post_deleteUser', 'OC_SubAdmin', 'post_deleteUser');
OC_Hook::connect('OC_User', 'post_deleteGroup', 'OC_SubAdmin', 'post_deleteGroup');
/**
* This class provides all methods needed for managing groups.
*
* Hooks provided:
* post_createSubAdmin($gid)
* post_deleteSubAdmin($gid)
*/
class OC_SubAdmin{
/**
|
|
6d9380f96
|
34 35 36 |
* add a SubAdmin * @param string $uid uid of the SubAdmin * @param string $gid gid of the group |
|
03e52840d
|
37 38 39 40 41 42 43 44 45 46 |
* @return boolean
*/
public static function createSubAdmin($uid, $gid) {
$stmt = OC_DB::prepare('INSERT INTO `*PREFIX*group_admin` (`gid`,`uid`) VALUES(?,?)');
$result = $stmt->execute(array($gid, $uid));
OC_Hook::emit( "OC_SubAdmin", "post_createSubAdmin", array( "gid" => $gid ));
return true;
}
/**
|
|
6d9380f96
|
47 48 49 |
* delete a SubAdmin * @param string $uid uid of the SubAdmin * @param string $gid gid of the group |
|
03e52840d
|
50 51 52 53 54 55 56 57 58 59 |
* @return boolean
*/
public static function deleteSubAdmin($uid, $gid) {
$stmt = OC_DB::prepare('DELETE FROM `*PREFIX*group_admin` WHERE `gid` = ? AND `uid` = ?');
$result = $stmt->execute(array($gid, $uid));
OC_Hook::emit( "OC_SubAdmin", "post_deleteSubAdmin", array( "gid" => $gid ));
return true;
}
/**
|
|
6d9380f96
|
60 61 |
* get groups of a SubAdmin * @param string $uid uid of the SubAdmin |
|
03e52840d
|
62 63 64 65 66 67 68 69 70 71 72 73 74 |
* @return array
*/
public static function getSubAdminsGroups($uid) {
$stmt = OC_DB::prepare('SELECT `gid` FROM `*PREFIX*group_admin` WHERE `uid` = ?');
$result = $stmt->execute(array($uid));
$gids = array();
while($row = $result->fetchRow()) {
$gids[] = $row['gid'];
}
return $gids;
}
/**
|
|
6d9380f96
|
75 76 |
* get SubAdmins of a group * @param string $gid gid of the group |
|
03e52840d
|
77 78 79 80 81 82 83 84 85 86 87 88 89 |
* @return array
*/
public static function getGroupsSubAdmins($gid) {
$stmt = OC_DB::prepare('SELECT `uid` FROM `*PREFIX*group_admin` WHERE `gid` = ?');
$result = $stmt->execute(array($gid));
$uids = array();
while($row = $result->fetchRow()) {
$uids[] = $row['uid'];
}
return $uids;
}
/**
|
|
6d9380f96
|
90 |
* get all SubAdmins |
|
03e52840d
|
91 92 93 94 95 96 97 98 99 100 101 102 103 |
* @return array
*/
public static function getAllSubAdmins() {
$stmt = OC_DB::prepare('SELECT * FROM `*PREFIX*group_admin`');
$result = $stmt->execute();
$subadmins = array();
while($row = $result->fetchRow()) {
$subadmins[] = $row;
}
return $subadmins;
}
/**
|
|
6d9380f96
|
104 105 106 |
* checks if a user is a SubAdmin of a group * @param string $uid uid of the subadmin * @param string $gid gid of the group |
|
03e52840d
|
107 108 109 110 111 112 113 114 115 116 117 118 119 |
* @return bool
*/
public static function isSubAdminofGroup($uid, $gid) {
$stmt = OC_DB::prepare('SELECT COUNT(*) AS `count` FROM `*PREFIX*group_admin` WHERE `uid` = ? AND `gid` = ?');
$result = $stmt->execute(array($uid, $gid));
$result = $result->fetchRow();
if($result['count'] >= 1) {
return true;
}
return false;
}
/**
|
|
6d9380f96
|
120 121 |
* checks if a user is a SubAdmin * @param string $uid uid of the subadmin |
|
03e52840d
|
122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 |
* @return bool
*/
public static function isSubAdmin($uid) {
// Check if the user is already an admin
if(OC_Group::inGroup($uid, 'admin' )) {
return true;
}
$stmt = OC_DB::prepare('SELECT COUNT(*) AS `count` FROM `*PREFIX*group_admin` WHERE `uid` = ?');
$result = $stmt->execute(array($uid));
$result = $result->fetchRow();
if($result['count'] > 0) {
return true;
}
return false;
}
/**
|
|
6d9380f96
|
140 141 142 |
* checks if a user is a accessible by a subadmin * @param string $subadmin uid of the subadmin * @param string $user uid of the user |
|
03e52840d
|
143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 |
* @return bool
*/
public static function isUserAccessible($subadmin, $user) {
if(!self::isSubAdmin($subadmin)) {
return false;
}
if(OC_User::isAdminUser($user)) {
return false;
}
$accessiblegroups = self::getSubAdminsGroups($subadmin);
foreach($accessiblegroups as $accessiblegroup) {
if(OC_Group::inGroup($user, $accessiblegroup)) {
return true;
}
}
return false;
}
/*
|
|
6d9380f96
|
162 |
* alias for self::isSubAdminofGroup() |
|
03e52840d
|
163 164 165 166 167 168 |
*/
public static function isGroupAccessible($subadmin, $group) {
return self::isSubAdminofGroup($subadmin, $group);
}
/**
|
|
6d9380f96
|
169 170 |
* delete all SubAdmins by uid * @param array $parameters |
|
03e52840d
|
171 172 173 174 175 176 177 178 179 |
* @return boolean
*/
public static function post_deleteUser($parameters) {
$stmt = OC_DB::prepare('DELETE FROM `*PREFIX*group_admin` WHERE `uid` = ?');
$result = $stmt->execute(array($parameters['uid']));
return true;
}
/**
|
|
6d9380f96
|
180 181 |
* delete all SubAdmins by gid * @param array $parameters |
|
03e52840d
|
182 183 184 185 186 187 188 189 |
* @return boolean
*/
public static function post_deleteGroup($parameters) {
$stmt = OC_DB::prepare('DELETE FROM `*PREFIX*group_admin` WHERE `gid` = ?');
$result = $stmt->execute(array($parameters['gid']));
return true;
}
}
|