togglesubadmins.php 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. <?php
  2. /**
  3. * @copyright Copyright (c) 2016, ownCloud, Inc.
  4. *
  5. * @author Bart Visscher <bartv@thisnet.nl>
  6. * @author Georg Ehrke <georg@owncloud.com>
  7. * @author Lukas Reschke <lukas@statuscode.ch>
  8. *
  9. * @license AGPL-3.0
  10. *
  11. * This code is free software: you can redistribute it and/or modify
  12. * it under the terms of the GNU Affero General Public License, version 3,
  13. * as published by the Free Software Foundation.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU Affero General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU Affero General Public License, version 3,
  21. * along with this program. If not, see <http://www.gnu.org/licenses/>
  22. *
  23. */
  24. OC_JSON::checkAdminUser();
  25. OCP\JSON::callCheck();
  26. $lastConfirm = (int) \OC::$server->getSession()->get('last-password-confirm');
  27. if ($lastConfirm < (time() - 30 * 60 + 15)) { // allow 15 seconds delay
  28. $l = \OC::$server->getL10N('core');
  29. OC_JSON::error(array( 'data' => array( 'message' => $l->t('Password confirmation is required'))));
  30. exit();
  31. }
  32. $username = (string)$_POST['username'];
  33. $group = (string)$_POST['group'];
  34. $subAdminManager = \OC::$server->getGroupManager()->getSubAdmin();
  35. $targetUserObject = \OC::$server->getUserManager()->get($username);
  36. $targetGroupObject = \OC::$server->getGroupManager()->get($group);
  37. $isSubAdminOfGroup = false;
  38. if($targetUserObject !== null && $targetUserObject !== null) {
  39. $isSubAdminOfGroup = $subAdminManager->isSubAdminofGroup($targetUserObject, $targetGroupObject);
  40. }
  41. // Toggle group
  42. if($isSubAdminOfGroup) {
  43. $subAdminManager->deleteSubAdmin($targetUserObject, $targetGroupObject);
  44. } else {
  45. $subAdminManager->createSubAdmin($targetUserObject, $targetGroupObject);
  46. }
  47. OC_JSON::success();