index.php 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354
  1. <?php
  2. use function Hestiacp\quoteshellarg\quoteshellarg;
  3. ob_start();
  4. include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
  5. // Check token
  6. verify_csrf($_POST);
  7. $user = $_POST['user'];
  8. $action = $_POST['action'];
  9. if ($_SESSION['userContext'] === 'admin') {
  10. switch ($action) {
  11. case 'delete': $cmd='v-delete-user'; $restart = 'no';
  12. break;
  13. case 'suspend': $cmd='v-suspend-user'; $restart = 'no';
  14. break;
  15. case 'unsuspend': $cmd='v-unsuspend-user'; $restart = 'no';
  16. break;
  17. case 'update counters': $cmd='v-update-user-counters';
  18. break;
  19. case 'rebuild': $cmd='v-rebuild-all'; $restart = 'no';
  20. break;
  21. case 'rebuild user': $cmd='v-rebuild-user'; $restart = 'no';
  22. break;
  23. case 'rebuild web': $cmd='v-rebuild-web-domains'; $restart = 'no';
  24. break;
  25. case 'rebuild dns': $cmd='v-rebuild-dns-domains'; $restart = 'no';
  26. break;
  27. case 'rebuild mail': $cmd='v-rebuild-mail-domains';
  28. break;
  29. case 'rebuild db': $cmd='v-rebuild-databases';
  30. break;
  31. case 'rebuild cron': $cmd='v-rebuild-cron-jobs';
  32. break;
  33. default: header("Location: /list/user/"); exit;
  34. }
  35. } else {
  36. switch ($action) {
  37. case 'update counters': $cmd='v-update-user-counters';
  38. break;
  39. default: header("Location: /list/user/"); exit;
  40. }
  41. }
  42. foreach ($user as $value) {
  43. $value = quoteshellarg($value);
  44. exec(HESTIA_CMD.$cmd." ".$value." ".$restart, $output, $return_var);
  45. $changes = 'yes';
  46. }
  47. header("Location: /list/user/");