index.php 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  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. if (empty($_POST["user"])) {
  8. header("Location: /list/user");
  9. exit();
  10. }
  11. if (empty($_POST["action"])) {
  12. header("Location: /list/user");
  13. exit();
  14. }
  15. $user = $_POST["user"];
  16. $action = $_POST["action"];
  17. if ($_SESSION["userContext"] === "admin") {
  18. switch ($action) {
  19. case "delete":
  20. $cmd = "v-delete-user";
  21. $restart = "no";
  22. break;
  23. case "suspend":
  24. $cmd = "v-suspend-user";
  25. $restart = "yes";
  26. break;
  27. case "unsuspend":
  28. $cmd = "v-unsuspend-user";
  29. $restart = "yes";
  30. break;
  31. case "update counters":
  32. $cmd = "v-update-user-counters";
  33. break;
  34. case "rebuild":
  35. $cmd = "v-rebuild-all";
  36. $restart = "no";
  37. break;
  38. case "rebuild user":
  39. $cmd = "v-rebuild-user";
  40. $restart = "no";
  41. break;
  42. case "rebuild web":
  43. $cmd = "v-rebuild-web-domains";
  44. break;
  45. case "rebuild dns":
  46. $cmd = "v-rebuild-dns-domains";
  47. break;
  48. case "rebuild mail":
  49. $cmd = "v-rebuild-mail-domains";
  50. break;
  51. case "rebuild db":
  52. $cmd = "v-rebuild-databases";
  53. break;
  54. case "rebuild cron":
  55. $cmd = "v-rebuild-cron-jobs";
  56. break;
  57. default:
  58. header("Location: /list/user/");
  59. exit();
  60. }
  61. } else {
  62. switch ($action) {
  63. case "update counters":
  64. $cmd = "v-update-user-counters";
  65. break;
  66. default:
  67. header("Location: /list/user/");
  68. exit();
  69. }
  70. }
  71. foreach ($user as $value) {
  72. $value = quoteshellarg($value);
  73. exec(HESTIA_CMD . $cmd . " " . $value . " " . $restart, $output, $return_var);
  74. $changes = "yes";
  75. }
  76. header("Location: /list/user/");