index.php 2.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081
  1. <?php
  2. // Init
  3. error_reporting(null);
  4. ob_start();
  5. session_start();
  6. include($_SERVER['DOCUMENT_ROOT']."/inc/main.php");
  7. // Check token
  8. verify_csrf($_POST);
  9. $domain = $_POST['domain'];
  10. $account = $_POST['account'];
  11. $action = $_POST['action'];
  12. if ($_SESSION['userContext'] === 'admin') {
  13. if (empty($account)) {
  14. switch ($action) {
  15. case 'rebuild': $cmd='v-rebuild-mail-domain';
  16. break;
  17. case 'delete': $cmd='v-delete-mail-domain';
  18. break;
  19. case 'suspend': $cmd='v-suspend-mail-domain';
  20. break;
  21. case 'unsuspend': $cmd='v-unsuspend-mail-domain';
  22. break;
  23. default: header("Location: /list/mail/"); exit;
  24. }
  25. } else {
  26. switch ($action) {
  27. case 'delete': $cmd='v-delete-mail-account';
  28. break;
  29. case 'suspend': $cmd='v-suspend-mail-account';
  30. break;
  31. case 'unsuspend': $cmd='v-unsuspend-mail-account';
  32. break;
  33. default: header("Location: /list/mail/?domain=".$domain); exit;
  34. }
  35. }
  36. } else {
  37. if (empty($account)) {
  38. switch ($action) {
  39. case 'delete': $cmd='v-delete-mail-domain';
  40. break;
  41. default: header("Location: /list/mail/"); exit;
  42. }
  43. } else {
  44. switch ($action) {
  45. case 'delete': $cmd='v-delete-mail-account';
  46. break;
  47. default: header("Location: /list/mail/?domain=".$domain); exit;
  48. }
  49. }
  50. }
  51. if (empty($account)) {
  52. foreach ($domain as $value) {
  53. // Mail
  54. $value = escapeshellarg($value);
  55. exec(HESTIA_CMD.$cmd." ".$user." ".$value, $output, $return_var);
  56. $restart = 'yes';
  57. }
  58. } else {
  59. foreach ($account as $value) {
  60. // Mail Account
  61. $value = escapeshellarg($value);
  62. $dom = escapeshellarg($domain);
  63. exec(HESTIA_CMD.$cmd." ".$user." ".$dom." ".$value, $output, $return_var);
  64. $restart = 'yes';
  65. }
  66. }
  67. if (empty($account)) {
  68. header("Location: /list/mail/");
  69. exit;
  70. } else {
  71. header("Location: /list/mail/?domain=".$domain);
  72. exit;
  73. }