edit.php 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. <?php
  2. require_once $_SERVER['DOCUMENT_ROOT'] . '/inc/prerequisites.inc.php';
  3. $AuthUsers = array("admin", "domainadmin", "user");
  4. if (!isset($_SESSION['mailcow_cc_role']) OR !in_array($_SESSION['mailcow_cc_role'], $AuthUsers)) {
  5. header('Location: /');
  6. exit();
  7. }
  8. require_once $_SERVER['DOCUMENT_ROOT'] . '/inc/header.inc.php';
  9. $template = 'edit.twig';
  10. $template_data = [];
  11. $result = null;
  12. if (isset($_SESSION['mailcow_cc_role'])) {
  13. if ($_SESSION['mailcow_cc_role'] == "admin" || $_SESSION['mailcow_cc_role'] == "domainadmin") {
  14. if (isset($_GET["alias"]) &&
  15. !empty($_GET["alias"])) {
  16. $alias = html_entity_decode(rawurldecode($_GET["alias"]));
  17. $result = mailbox('get', 'alias_details', $alias);
  18. $template = 'edit/alias.twig';
  19. $template_data = [
  20. 'alias' => $alias,
  21. 'goto' => (preg_match('/^(null|ham|spam)@localhost$/i', $result['goto'])) ? null : $result['goto'],
  22. ];
  23. }
  24. elseif (isset($_GET['domainadmin'])) {
  25. $domain_admin = $_GET["domainadmin"];
  26. $result = domain_admin('details', $domain_admin);
  27. $template = 'edit/domainadmin.twig';
  28. $template_data = [
  29. 'domain_admin' => $domain_admin,
  30. 'da_acls' => acl('get', 'domainadmin', $domain_admin),
  31. ];
  32. }
  33. elseif (isset($_GET['admin'])) {
  34. $admin = $_GET["admin"];
  35. $result = admin('details', $admin);
  36. $template = 'edit/admin.twig';
  37. $template_data = ['admin' => $admin];
  38. }
  39. elseif (isset($_GET['domain']) &&
  40. is_valid_domain_name($_GET["domain"]) &&
  41. !empty($_GET["domain"])) {
  42. $domain = $_GET["domain"];
  43. $result = mailbox('get', 'domain_details', $domain);
  44. $quota_notification_bcc = quota_notification_bcc('get', $domain);
  45. $rl = ratelimit('get', 'domain', $domain);
  46. $rlyhosts = relayhost('get');
  47. $template = 'edit/domain.twig';
  48. $template_data = [
  49. 'acl' => $_SESSION['acl'],
  50. 'domain' => $domain,
  51. 'quota_notification_bcc' => $quota_notification_bcc,
  52. 'rl' => $rl,
  53. 'rlyhosts' => $rlyhosts,
  54. 'dkim' => dkim('details', $domain),
  55. 'domain_details' => $result,
  56. ];
  57. }
  58. elseif (isset($_GET['oauth2client']) &&
  59. is_numeric($_GET["oauth2client"]) &&
  60. !empty($_GET["oauth2client"])) {
  61. $oauth2client = $_GET["oauth2client"];
  62. $result = oauth2('details', 'client', $oauth2client);
  63. $template = 'edit/oauth2client.twig';
  64. $template_data = ['oauth2client' => $oauth2client];
  65. }
  66. elseif (isset($_GET['aliasdomain']) &&
  67. is_valid_domain_name(html_entity_decode(rawurldecode($_GET["aliasdomain"]))) &&
  68. !empty($_GET["aliasdomain"])) {
  69. $alias_domain = html_entity_decode(rawurldecode($_GET["aliasdomain"]));
  70. $result = mailbox('get', 'alias_domain_details', $alias_domain);
  71. $rl = ratelimit('get', 'domain', $alias_domain);
  72. $template = 'edit/aliasdomain.twig';
  73. $template_data = [
  74. 'alias_domain' => $alias_domain,
  75. 'rl' => $rl,
  76. 'domains' => mailbox('get', 'domains'),
  77. 'dkim' => dkim('details', $alias_domain),
  78. ];
  79. }
  80. elseif (isset($_GET['mailbox']) && filter_var(html_entity_decode(rawurldecode($_GET["mailbox"])), FILTER_VALIDATE_EMAIL) && !empty($_GET["mailbox"])) {
  81. $mailbox = html_entity_decode(rawurldecode($_GET["mailbox"]));
  82. $result = mailbox('get', 'mailbox_details', $mailbox);
  83. $rl = ratelimit('get', 'mailbox', $mailbox);
  84. $pushover_data = pushover('get', $mailbox);
  85. $quarantine_notification = mailbox('get', 'quarantine_notification', $mailbox);
  86. $quarantine_category = mailbox('get', 'quarantine_category', $mailbox);
  87. $get_tls_policy = mailbox('get', 'tls_policy', $mailbox);
  88. $rlyhosts = relayhost('get');
  89. $template = 'edit/mailbox.twig';
  90. $template_data = [
  91. 'acl' => $_SESSION['acl'],
  92. 'mailbox' => $mailbox,
  93. 'rl' => $rl,
  94. 'pushover_data' => $pushover_data,
  95. 'quarantine_notification' => $quarantine_notification,
  96. 'quarantine_category' => $quarantine_category,
  97. 'get_tls_policy' => $get_tls_policy,
  98. 'rlyhosts' => $rlyhosts,
  99. 'sender_acl_handles' => mailbox('get', 'sender_acl_handles', $mailbox),
  100. 'user_acls' => acl('get', 'user', $mailbox),
  101. 'mailbox_details' => $result
  102. ];
  103. }
  104. elseif (isset($_GET['relayhost']) && is_numeric($_GET["relayhost"]) && !empty($_GET["relayhost"])) {
  105. $relayhost = intval($_GET["relayhost"]);
  106. $result = relayhost('details', $relayhost);
  107. $template = 'edit/relayhost.twig';
  108. $template_data = ['relayhost' => $relayhost];
  109. }
  110. elseif (isset($_GET['transport']) && is_numeric($_GET["transport"]) && !empty($_GET["transport"])) {
  111. $transport = intval($_GET["transport"]);
  112. $result = transport('details', $transport);
  113. $template = 'edit/transport.twig';
  114. $template_data = ['transport' => $transport];
  115. }
  116. elseif (isset($_GET['resource']) && filter_var(html_entity_decode(rawurldecode($_GET["resource"])), FILTER_VALIDATE_EMAIL) && !empty($_GET["resource"])) {
  117. $resource = html_entity_decode(rawurldecode($_GET["resource"]));
  118. $result = mailbox('get', 'resource_details', $resource);
  119. $template = 'edit/resource.twig';
  120. }
  121. elseif (isset($_GET['bcc']) && !empty($_GET["bcc"])) {
  122. $bcc = intval($_GET["bcc"]);
  123. $result = bcc('details', $bcc);
  124. $template = 'edit/bcc.twig';
  125. $template_data = ['bcc' => $bcc];
  126. }
  127. elseif (isset($_GET['recipient_map']) &&
  128. !empty($_GET["recipient_map"]) &&
  129. $_SESSION['mailcow_cc_role'] == "admin") {
  130. $map = intval($_GET["recipient_map"]);
  131. $result = recipient_map('details', $map);
  132. if (substr($result['recipient_map_old'], 0, 1) == '@') {
  133. $result['recipient_map_old'] = substr($result['recipient_map_old'], 1);
  134. }
  135. $template = 'edit/recipient_map.twig';
  136. $template_data = ['map' => $map];
  137. }
  138. elseif (isset($_GET['tls_policy_map']) &&
  139. !empty($_GET["tls_policy_map"]) &&
  140. $_SESSION['mailcow_cc_role'] == "admin") {
  141. $map = intval($_GET["tls_policy_map"]);
  142. $result = tls_policy_maps('details', $map);
  143. $template = 'edit/tls_policy_map.twig';
  144. $template_data = [
  145. 'map' => $map,
  146. 'policy_options' => [
  147. 'none',
  148. 'may',
  149. 'encrypt',
  150. 'dane',
  151. 'dane-only',
  152. 'fingerprint',
  153. 'verify',
  154. 'secure',
  155. ],
  156. ];
  157. }
  158. }
  159. if ($_SESSION['mailcow_cc_role'] == "admin" || $_SESSION['mailcow_cc_role'] == "domainadmin" || $_SESSION['mailcow_cc_role'] == "user") {
  160. if (isset($_GET['syncjob']) &&
  161. is_numeric($_GET['syncjob'])) {
  162. $id = $_GET["syncjob"];
  163. $result = mailbox('get', 'syncjob_details', $id);
  164. $template = 'edit/syncjob.twig';
  165. }
  166. elseif (isset($_GET['filter']) &&
  167. is_numeric($_GET['filter'])) {
  168. $id = $_GET["filter"];
  169. $result = mailbox('get', 'filter_details', $id);
  170. $template = 'edit/filter.twig';
  171. }
  172. elseif (isset($_GET['app-passwd']) &&
  173. is_numeric($_GET['app-passwd'])) {
  174. $id = $_GET["app-passwd"];
  175. $result = app_passwd('details', $id);
  176. $template = 'edit/app-passwd.twig';
  177. }
  178. }
  179. }
  180. else {
  181. $template_data['access_denied'] = true;
  182. }
  183. $js_minifier->add('/web/js/site/edit.js');
  184. $js_minifier->add('/web/js/site/pwgen.js');
  185. $template_data['result'] = $result;
  186. $template_data['return_to'] = $_SESSION['return_to'];
  187. $template_data['lang_user'] = json_encode($lang['user']);
  188. require_once $_SERVER['DOCUMENT_ROOT'] . '/inc/footer.inc.php';