Blame view

sources/lib/private/subadmin.php 5.17 KB
03e52840d   Kload   Init
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   Cédric Dupont   Update sources OC...
34
35
36
  	 * add a SubAdmin
  	 * @param string $uid uid of the SubAdmin
  	 * @param string $gid gid of the group
03e52840d   Kload   Init
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   Cédric Dupont   Update sources OC...
47
48
49
  	 * delete a SubAdmin
  	 * @param string $uid uid of the SubAdmin
  	 * @param string $gid gid of the group
03e52840d   Kload   Init
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   Cédric Dupont   Update sources OC...
60
61
  	 * get groups of a SubAdmin
  	 * @param string $uid uid of the SubAdmin
03e52840d   Kload   Init
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   Cédric Dupont   Update sources OC...
75
76
  	 * get SubAdmins of a group
  	 * @param string $gid gid of the group
03e52840d   Kload   Init
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   Cédric Dupont   Update sources OC...
90
  	 * get all SubAdmins
03e52840d   Kload   Init
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   Cédric Dupont   Update sources OC...
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   Kload   Init
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   Cédric Dupont   Update sources OC...
120
121
  	 * checks if a user is a SubAdmin
  	 * @param string $uid uid of the subadmin
03e52840d   Kload   Init
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   Cédric Dupont   Update sources OC...
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   Kload   Init
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   Cédric Dupont   Update sources OC...
162
  	 * alias for self::isSubAdminofGroup()
03e52840d   Kload   Init
163
164
165
166
167
168
  	 */
  	public static function isGroupAccessible($subadmin, $group) {
  		return self::isSubAdminofGroup($subadmin, $group);
  	}
  
  	/**
6d9380f96   Cédric Dupont   Update sources OC...
169
170
  	 * delete all SubAdmins by uid
  	 * @param array $parameters
03e52840d   Kload   Init
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   Cédric Dupont   Update sources OC...
180
181
  	 * delete all SubAdmins by gid
  	 * @param array $parameters
03e52840d   Kload   Init
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;
  	}
  }