admin.php 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. <?php
  2. require_once $_SERVER['DOCUMENT_ROOT'] . '/inc/prerequisites.inc.php';
  3. if (!isset($_SESSION['mailcow_cc_role']) || $_SESSION['mailcow_cc_role'] != "admin") {
  4. header('Location: /');
  5. exit();
  6. }
  7. require_once $_SERVER['DOCUMENT_ROOT'] . '/inc/header.inc.php';
  8. $_SESSION['return_to'] = $_SERVER['REQUEST_URI'];
  9. $tfa_data = get_tfa();
  10. $fido2_data = fido2(array("action" => "get_friendly_names"));
  11. if (!isset($_SESSION['gal']) && $license_cache = $redis->Get('LICENSE_STATUS_CACHE')) {
  12. $_SESSION['gal'] = json_decode($license_cache, true);
  13. }
  14. $js_minifier->add('/web/js/site/admin.js');
  15. $js_minifier->add('/web/js/presets/rspamd.js');
  16. $js_minifier->add('/web/js/site/pwgen.js');
  17. // all domains
  18. $domains = mailbox('get', 'domains');
  19. $all_domains = array_merge($domains, mailbox('get', 'alias_domains'));
  20. // mailboxes
  21. $mailboxes = [];
  22. foreach ($all_domains as $domain) {
  23. foreach (mailbox('get', 'mailboxes', $domain) as $mailbox) {
  24. $mailboxes[] = $mailbox;
  25. }
  26. }
  27. $mailboxes = array_filter($mailboxes);
  28. // DKIM domains
  29. $dkim_domains = [];
  30. $dkim_domains_with_keys = [];
  31. foreach($domains as $domain) {
  32. $dkim_domains[$domain] = ['dkim' => null, 'alias_domains' => []];
  33. if (!empty($dkim = dkim('details', $domain))) {
  34. $dkim_domains_with_keys[] = $domain;
  35. if ($GLOBALS['SHOW_DKIM_PRIV_KEYS'] !== true) {
  36. $dkim['privkey'] = base64_encode('Please set $SHOW_DKIM_PRIV_KEYS to true to show DKIM private keys.');
  37. }
  38. $dkim_domains[$domain]['dkim'] = $dkim;
  39. }
  40. // get alias domains
  41. foreach (mailbox('get', 'alias_domains', $domain) as $alias_domain) {
  42. $dkim_domains[$domain]['alias_domains'][$alias_domain] = ['dkim' => null];
  43. if (!empty($dkim = dkim('details', $alias_domain))) {
  44. $dkim_domains_with_keys[] = $alias_domain;
  45. if ($GLOBALS['SHOW_DKIM_PRIV_KEYS'] !== true) {
  46. $dkim['privkey'] = base64_encode('Please set $SHOW_DKIM_PRIV_KEYS to true to show DKIM private keys.');
  47. }
  48. $dkim_domains[$domain]['alias_domains'][$alias_domain]['dkim'] = $dkim;
  49. }
  50. }
  51. }
  52. $dkim_blind_domains = [];
  53. foreach(dkim('blind') as $blind) {
  54. $dkim_blind_domains[$blind] = ['dkim' => null];
  55. if (!empty($dkim = dkim('details', $blind))) {
  56. $dkim_domains_with_keys[] = $blind;
  57. if ($GLOBALS['SHOW_DKIM_PRIV_KEYS'] !== true) {
  58. $dkim['privkey'] = base64_encode('Please set $SHOW_DKIM_PRIV_KEYS to true to show DKIM private keys.');
  59. }
  60. $dkim_blind_domains[$blind]['dkim'] = $dkim;
  61. }
  62. }
  63. // rsettings
  64. $rsettings = array_map(function ($rsetting){
  65. $rsetting['details'] = rsettings('details', $rsetting['id']);
  66. return $rsetting;
  67. }, rsettings('get'));
  68. // rspamd regex maps
  69. $rspamd_regex_maps = [];
  70. foreach ($RSPAMD_MAPS['regex'] as $rspamd_regex_desc => $rspamd_regex_map) {
  71. $rspamd_regex_maps[$rspamd_regex_desc] = [
  72. 'map' => $rspamd_regex_map,
  73. 'data' => file_get_contents('/rspamd_custom_maps/' . $rspamd_regex_map)
  74. ];
  75. }
  76. $template = 'admin.twig';
  77. $template_data = [
  78. 'tfa_data' => $tfa_data,
  79. 'tfa_id' => @$_SESSION['tfa_id'],
  80. 'fido2_cid' => @$_SESSION['fido2_cid'],
  81. 'fido2_data' => $fido2_data,
  82. 'gal' => @$_SESSION['gal'],
  83. 'license_guid' => license('guid'),
  84. 'api' => [
  85. 'ro' => admin_api('ro', 'get'),
  86. 'rw' => admin_api('rw', 'get'),
  87. ],
  88. 'dkim_domains' => $dkim_domains,
  89. 'dkim_domains_with_keys' => $dkim_domains_with_keys,
  90. 'dkim_blind_domains' => $dkim_blind_domains,
  91. 'domains' => $domains,
  92. 'all_domains' => $all_domains,
  93. 'mailboxes' => $mailboxes,
  94. 'f2b_data' => fail2ban('get'),
  95. 'q_data' => quarantine('settings'),
  96. 'qn_data' => quota_notification('get'),
  97. 'rsettings_map' => file_get_contents('http://nginx:8081/settings.php'),
  98. 'rsettings' => $rsettings,
  99. 'rspamd_regex_maps' => $rspamd_regex_maps,
  100. 'logo_specs' => customize('get', 'main_logo_specs'),
  101. 'password_complexity' => password_complexity('get'),
  102. 'show_rspamd_global_filters' => @$_SESSION['show_rspamd_global_filters'],
  103. 'lang_admin' => json_encode($lang['admin']),
  104. ];
  105. require_once $_SERVER['DOCUMENT_ROOT'] . '/inc/footer.inc.php';