vars.inc.php 7.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  1. <?php
  2. error_reporting(E_ERROR);
  3. //error_reporting(E_ALL);
  4. /*
  5. PLEASE USE THE FILE "vars.local.inc.php" TO OVERWRITE SETTINGS AND MAKE THEM PERSISTENT!
  6. This file will be reset on upgrades.
  7. */
  8. // SQL database connection variables
  9. $database_type = 'mysql';
  10. $database_sock = '/var/run/mysqld/mysqld.sock';
  11. $database_host = 'mysql';
  12. $database_user = getenv('DBUSER');
  13. $database_pass = getenv('DBPASS');
  14. $database_name = getenv('DBNAME');
  15. // Other variables
  16. $mailcow_hostname = getenv('MAILCOW_HOSTNAME');
  17. $default_pass_scheme = getenv('MAILCOW_PASS_SCHEME');
  18. // Autodiscover settings
  19. // ===
  20. // Auto-detect HTTPS port =>
  21. $https_port = strpos($_SERVER['HTTP_HOST'], ':');
  22. if ($https_port === FALSE) {
  23. $https_port = 443;
  24. } else {
  25. $https_port = substr($_SERVER['HTTP_HOST'], $https_port+1);
  26. }
  27. // Alternatively select port here =>
  28. //$https_port = 1234;
  29. // Other settings =>
  30. $autodiscover_config = array(
  31. // General autodiscover service type: "activesync" or "imap"
  32. // emClient uses autodiscover, but does not support ActiveSync. mailcow excludes emClient from ActiveSync.
  33. // With SOGo disabled, the type will always fallback to imap. CalDAV and CardDAV will be excluded, too.
  34. 'autodiscoverType' => 'activesync',
  35. // If autodiscoverType => activesync, also use ActiveSync (EAS) for Outlook desktop clients (>= Outlook 2013 on Windows)
  36. // Outlook for Mac does not support ActiveSync
  37. 'useEASforOutlook' => 'no',
  38. // Please don't use STARTTLS-enabled service ports in the "port" variable.
  39. // The autodiscover service will always point to SMTPS and IMAPS (TLS-wrapped services).
  40. // The autoconfig service will additionally announce the STARTTLS-enabled ports, specified in the "tlsport" variable.
  41. 'imap' => array(
  42. 'server' => $mailcow_hostname,
  43. 'port' => end(explode(':', getenv('IMAPS_PORT'))),
  44. 'tlsport' => end(explode(':', getenv('IMAP_PORT'))),
  45. ),
  46. 'pop3' => array(
  47. 'server' => $mailcow_hostname,
  48. 'port' => end(explode(':', getenv('POPS_PORT'))),
  49. 'tlsport' => end(explode(':', getenv('POP_PORT'))),
  50. ),
  51. 'smtp' => array(
  52. 'server' => $mailcow_hostname,
  53. 'port' => end(explode(':', getenv('SMTPS_PORT'))),
  54. 'tlsport' => end(explode(':', getenv('SUBMISSION_PORT'))),
  55. ),
  56. 'activesync' => array(
  57. 'url' => 'https://'.$mailcow_hostname.($https_port == 443 ? '' : ':'.$https_port).'/Microsoft-Server-ActiveSync',
  58. ),
  59. 'caldav' => array(
  60. 'server' => $mailcow_hostname,
  61. 'port' => $https_port,
  62. ),
  63. 'carddav' => array(
  64. 'server' => $mailcow_hostname,
  65. 'port' => $https_port,
  66. ),
  67. );
  68. // If false, we will use DEFAULT_LANG
  69. // Uses HTTP_ACCEPT_LANGUAGE header
  70. $DETECT_LANGUAGE = true;
  71. // Change default language
  72. $DEFAULT_LANG = 'en';
  73. // Available languages
  74. $AVAILABLE_LANGUAGES = array('ca', 'cs', 'de', 'en', 'es', 'fi', 'fr', 'hu', 'it', 'ko', 'lv', 'nl', 'pl', 'pt', 'ro', 'ru', 'sk', 'sv', 'zh');
  75. // Change theme (default: lumen)
  76. // Needs to be one of those: cerulean, cosmo, cyborg, darkly, flatly, journal, lumen, paper, readable, sandstone,
  77. // simplex, slate, spacelab, superhero, united, yeti
  78. // See https://bootswatch.com/
  79. // WARNING: Only lumen is loaded locally. Enabling any other theme, will download external sources.
  80. $DEFAULT_THEME = 'lumen';
  81. // Password complexity as regular expression
  82. // Min. 6 characters
  83. $PASSWD_REGEP = '.{6,}';
  84. // Min. 6 characters, which must include at least one uppercase letter, one lowercase letter and one number
  85. // $PASSWD_REGEP = '^(?=.*[A-Z])(?=.*[0-9])(?=.*[a-z]).{6,}$';
  86. // Min. 6 characters, which must include at least one letter and one number
  87. // $PASSWD_REGEP = '^(?=.*[0-9])(?=.*[A-Za-z]).{6,}$';
  88. // Show DKIM private keys - false by default
  89. $SHOW_DKIM_PRIV_KEYS = false;
  90. // mailcow Apps - buttons on login screen
  91. $MAILCOW_APPS = array(
  92. array(
  93. 'name' => 'Webmail',
  94. 'link' => '/SOGo/',
  95. )
  96. );
  97. // Rows until pagination begins
  98. $PAGINATION_SIZE = 20;
  99. // Default number of rows/lines to display (log table)
  100. $LOG_LINES = 1000;
  101. // Rows until pagination begins (log table)
  102. $LOG_PAGINATION_SIZE = 50;
  103. // Session lifetime in seconds
  104. $SESSION_LIFETIME = 10800;
  105. // Label for OTP devices
  106. $OTP_LABEL = "mailcow UI";
  107. // Default "to" address in relay test tool
  108. $RELAY_TO = "null@hosted.mailcow.de";
  109. // How long to wait (in s) for cURL Docker requests
  110. $DOCKER_TIMEOUT = 60;
  111. // Anonymize IPs logged via UI
  112. $ANONYMIZE_IPS = true;
  113. // Split DKIM key notation (bind format)
  114. $SPLIT_DKIM_255 = false;
  115. // OAuth2 settings
  116. $REFRESH_TOKEN_LIFETIME = 2678400;
  117. $ACCESS_TOKEN_LIFETIME = 86400;
  118. // Logout from mailcow after first OAuth2 session profile request
  119. $OAUTH2_FORGET_SESSION_AFTER_LOGIN = false;
  120. // MAILBOX_DEFAULT_ATTRIBUTES define default attributes for new mailboxes
  121. // These settings will not change existing mailboxes
  122. // Force incoming TLS for new mailboxes by default
  123. $MAILBOX_DEFAULT_ATTRIBUTES['tls_enforce_in'] = false;
  124. // Force outgoing TLS for new mailboxes by default
  125. $MAILBOX_DEFAULT_ATTRIBUTES['tls_enforce_out'] = false;
  126. // Force password change on next login (only allows login to mailcow UI)
  127. $MAILBOX_DEFAULT_ATTRIBUTES['force_pw_update'] = false;
  128. // Enable SOGo access (set to false to disable access by default)
  129. $MAILBOX_DEFAULT_ATTRIBUTES['sogo_access'] = true;
  130. // Send notification when quarantine is not empty (never, hourly, daily, weekly)
  131. $MAILBOX_DEFAULT_ATTRIBUTES['quarantine_notification'] = 'hourly';
  132. // Mailbox has IMAP access by default
  133. $MAILBOX_DEFAULT_ATTRIBUTES['imap_access'] = true;
  134. // Mailbox has POP3 access by default
  135. $MAILBOX_DEFAULT_ATTRIBUTES['pop3_access'] = true;
  136. // Mailbox has SMTP access by default
  137. $MAILBOX_DEFAULT_ATTRIBUTES['smtp_access'] = true;
  138. // Mailbox receives notifications about...
  139. // "add_header" - mail that was put into the Junk folder
  140. // "reject" - mail that was rejected
  141. // "all" - mail that was rejected and put into the Junk folder
  142. $MAILBOX_DEFAULT_ATTRIBUTES['quarantine_category'] = 'reject';
  143. // Default mailbox format, should not be changed unless you know exactly, what you do, keep the trailing ":"
  144. // Check dovecot.conf for further changes (e.g. shared namespace)
  145. $MAILBOX_DEFAULT_ATTRIBUTES['mailbox_format'] = 'maildir:';
  146. // Show last IMAP and POP3 logins
  147. $SHOW_LAST_LOGIN = true;
  148. // UV flag handling in FIDO2/WebAuthn - defaults to false to allow iOS logins
  149. // true = required
  150. // false = preferred
  151. // string 'required' 'preferred' 'discouraged'
  152. $FIDO2_UV_FLAG_REGISTER = 'preferred';
  153. $FIDO2_UV_FLAG_LOGIN = 'preferred'; // iOS ignores the key via NFC if required - known issue
  154. $FIDO2_USER_PRESENT_FLAG = true;
  155. $FIDO2_FORMATS = array('apple', 'android-key', 'android-safetynet', 'fido-u2f', 'none', 'packed', 'tpm');
  156. // Set visible Rspamd maps in mailcow UI, do not change unless you know what you are doing
  157. $RSPAMD_MAPS = array(
  158. 'regex' => array(
  159. 'Header-From: Blacklist' => 'global_mime_from_blacklist.map',
  160. 'Header-From: Whitelist' => 'global_mime_from_whitelist.map',
  161. 'Envelope Sender Blacklist' => 'global_smtp_from_blacklist.map',
  162. 'Envelope Sender Whitelist' => 'global_smtp_from_whitelist.map',
  163. 'Recipient Blacklist' => 'global_rcpt_blacklist.map',
  164. 'Recipient Whitelist' => 'global_rcpt_whitelist.map',
  165. 'Fishy TLDS (only fired in combination with bad words)' => 'fishy_tlds.map',
  166. 'Bad Words (only fired in combination with fishy TLDs)' => 'bad_words.map',
  167. 'Bad Words DE (only fired in combination with fishy TLDs)' => 'bad_words_de.map',
  168. 'Bad Languages' => 'bad_languages.map',
  169. 'Bulk Mail Headers' => 'bulk_header.map',
  170. 'Monitoring Hosts' => 'monitoring_nolog.map'
  171. )
  172. );