Blame view

sources/settings/ajax/togglegroups.php 1.46 KB
03e52840d   Kload   Init
1
2
3
4
5
6
7
8
  <?php
  
  OC_JSON::checkSubAdminUser();
  OCP\JSON::callCheck();
  
  $success = true;
  $username = $_POST["username"];
  $group = $_POST["group"];
31b7f2792   Kload   Upgrade to ownclo...
9
  if($username === OC_User::getUser() && $group === "admin" &&  OC_User::isAdminUser($username)) {
03e52840d   Kload   Init
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
37
  	$l = OC_L10N::get('core');
  	OC_JSON::error(array( 'data' => array( 'message' => $l->t('Admins can\'t remove themself from the admin group'))));
  	exit();
  }
  
  if(!OC_User::isAdminUser(OC_User::getUser())
  	&& (!OC_SubAdmin::isUserAccessible(OC_User::getUser(), $username)
  		|| !OC_SubAdmin::isGroupAccessible(OC_User::getUser(), $group))) {
  	$l = OC_L10N::get('core');
  	OC_JSON::error(array( 'data' => array( 'message' => $l->t('Authentication error') )));
  	exit();
  }
  
  if(!OC_Group::groupExists($group)) {
  	OC_Group::createGroup($group);
  }
  
  $l = OC_L10N::get('settings');
  
  $error = $l->t("Unable to add user to group %s", $group);
  $action = "add";
  
  // Toggle group
  if( OC_Group::inGroup( $username, $group )) {
  	$action = "remove";
  	$error = $l->t("Unable to remove user from group %s", $group);
  	$success = OC_Group::removeFromGroup( $username, $group );
  	$usersInGroup=OC_Group::usersInGroup($group);
31b7f2792   Kload   Upgrade to ownclo...
38
  	if(count($usersInGroup) === 0) {
03e52840d   Kload   Init
39
40
41
42
43
44
45
46
47
48
49
50
51
52
  		OC_Group::deleteGroup($group);
  	}
  }
  else{
  	$success = OC_Group::addToGroup( $username, $group );
  }
  
  // Return Success story
  if( $success ) {
  	OC_JSON::success(array("data" => array( "username" => $username, "action" => $action, "groupname" => $group )));
  }
  else{
  	OC_JSON::error(array("data" => array( "message" => $error )));
  }