edit.php 9.4 KB

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