$https_port = strpos($_SERVER['HTTP_HOST'], ':'); if ($https_port === FALSE) { $https_port = 443; } else { $https_port = substr($_SERVER['HTTP_HOST'], $https_port+1); } // Alternatively select port here => //$https_port = 1234; // Other settings => $autodiscover_config = array( // General autodiscover service type: "activesync" or "imap" // emClient uses autodiscover, but does not support ActiveSync. mailcow excludes emClient from ActiveSync. // With SOGo disabled, the type will always fallback to imap. CalDAV and CardDAV will be excluded, too. 'autodiscoverType' => 'activesync', // If autodiscoverType => activesync, also use ActiveSync (EAS) for Outlook desktop clients (>= Outlook 2013 on Windows) // Outlook for Mac does not support ActiveSync 'useEASforOutlook' => 'no', // Please don't use STARTTLS-enabled service ports in the "port" variable. // The autodiscover service will always point to SMTPS and IMAPS (TLS-wrapped services). // The autoconfig service will additionally announce the STARTTLS-enabled ports, specified in the "tlsport" variable. 'imap' => array( 'server' => $mailcow_hostname, 'port' => (int)filter_var(substr(getenv('IMAPS_PORT'), strrpos(getenv('IMAPS_PORT'), ':')), FILTER_SANITIZE_NUMBER_INT), 'tlsport' => (int)filter_var(substr(getenv('IMAP_PORT'), strrpos(getenv('IMAP_PORT'), ':')), FILTER_SANITIZE_NUMBER_INT) ), 'pop3' => array( 'server' => $mailcow_hostname, 'port' => (int)filter_var(substr(getenv('POPS_PORT'), strrpos(getenv('POPS_PORT'), ':')), FILTER_SANITIZE_NUMBER_INT), 'tlsport' => (int)filter_var(substr(getenv('POP_PORT'), strrpos(getenv('POP_PORT'), ':')), FILTER_SANITIZE_NUMBER_INT) ), 'smtp' => array( 'server' => $mailcow_hostname, 'port' => (int)filter_var(substr(getenv('SMTPS_PORT'), strrpos(getenv('SMTPS_PORT'), ':')), FILTER_SANITIZE_NUMBER_INT), 'tlsport' => (int)filter_var(substr(getenv('SUBMISSION_PORT'), strrpos(getenv('SUBMISSION_PORT'), ':')), FILTER_SANITIZE_NUMBER_INT) ), 'activesync' => array( 'url' => 'https://' . $mailcow_hostname . ($https_port == 443 ? '' : ':' . $https_port) . '/Microsoft-Server-ActiveSync', ), 'caldav' => array( 'server' => $mailcow_hostname, 'port' => $https_port, ), 'carddav' => array( 'server' => $mailcow_hostname, 'port' => $https_port, ), ); // If false, we will use DEFAULT_LANG // Uses HTTP_ACCEPT_LANGUAGE header $DETECT_LANGUAGE = true; // Change default language $DEFAULT_LANG = 'en'; // Available languages // https://www.iso.org/obp/ui/#search // https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes $AVAILABLE_LANGUAGES = array( 'cs' => 'Čeština (Czech)', 'da' => 'Danish (Dansk)', 'de' => 'Deutsch (German)', 'en' => 'English', 'es' => 'Español (Spanish)', 'fi' => 'Suomi (Finish)', 'fr' => 'Français (French)', 'hu' => 'Magyar (Hungarian)', 'it' => 'Italiano (Italian)', 'ko' => '한국어 (Korean)', 'lv' => 'latviešu (Latvian)', 'nl' => 'Nederlands (Dutch)', 'pl' => 'Język Polski (Polish)', 'pt' => 'Português (Portuguese)', 'ro' => 'Română (Romanian)', 'ru' => 'Pусский (Russian)', 'sk' => 'Slovenčina (Slovak)', 'sv' => 'Svenska (Swedish)', 'tr' => 'Türkçe (Turkish)', 'uk' => 'Українська (Ukrainian)', 'zh' => '中文 (Chinese)' ); // default theme is lumen // additional themes can be found here: https://bootswatch.com/ // copy them to data/web/css/themes/{THEME-NAME}-bootstrap.css $UI_THEME = "lumen"; // Show DKIM private keys - false by default $SHOW_DKIM_PRIV_KEYS = false; // mailcow Apps - buttons on login screen $MAILCOW_APPS = array( array( 'name' => 'Webmail', 'link' => '/SOGo/', ) ); // Rows until pagination begins $PAGINATION_SIZE = 20; // Default number of rows/lines to display (log table) $LOG_LINES = 1000; // Rows until pagination begins (log table) $LOG_PAGINATION_SIZE = 50; // Session lifetime in seconds $SESSION_LIFETIME = 10800; // Label for OTP devices $OTP_LABEL = "mailcow UI"; // How long to wait (in s) for cURL Docker requests $DOCKER_TIMEOUT = 60; // Split DKIM key notation (bind format) $SPLIT_DKIM_255 = false; // OAuth2 settings $REFRESH_TOKEN_LIFETIME = 2678400; $ACCESS_TOKEN_LIFETIME = 86400; // Logout from mailcow after first OAuth2 session profile request $OAUTH2_FORGET_SESSION_AFTER_LOGIN = false; // Set a limit for mailbox and domain tagging $TAGGING_LIMIT = 25; // MAILBOX_DEFAULT_ATTRIBUTES define default attributes for new mailboxes // These settings will not change existing mailboxes // Force incoming TLS for new mailboxes by default $MAILBOX_DEFAULT_ATTRIBUTES['tls_enforce_in'] = false; // Force outgoing TLS for new mailboxes by default $MAILBOX_DEFAULT_ATTRIBUTES['tls_enforce_out'] = false; // Force password change on next login (only allows login to mailcow UI) $MAILBOX_DEFAULT_ATTRIBUTES['force_pw_update'] = false; // Enable SOGo access (set to false to disable access by default) $MAILBOX_DEFAULT_ATTRIBUTES['sogo_access'] = true; // Send notification when quarantine is not empty (never, hourly, daily, weekly) $MAILBOX_DEFAULT_ATTRIBUTES['quarantine_notification'] = 'hourly'; // Mailbox has IMAP access by default $MAILBOX_DEFAULT_ATTRIBUTES['imap_access'] = true; // Mailbox has POP3 access by default $MAILBOX_DEFAULT_ATTRIBUTES['pop3_access'] = true; // Mailbox has SMTP access by default $MAILBOX_DEFAULT_ATTRIBUTES['smtp_access'] = true; // Mailbox has sieve access by default $MAILBOX_DEFAULT_ATTRIBUTES['sieve_access'] = true; // Mailbox receives notifications about... // "add_header" - mail that was put into the Junk folder // "reject" - mail that was rejected // "all" - mail that was rejected and put into the Junk folder $MAILBOX_DEFAULT_ATTRIBUTES['quarantine_category'] = 'reject'; // Default mailbox format, should not be changed unless you know exactly, what you do, keep the trailing ":" // Check dovecot.conf for further changes (e.g. shared namespace) $MAILBOX_DEFAULT_ATTRIBUTES['mailbox_format'] = 'maildir:'; // Show last IMAP and POP3 logins $SHOW_LAST_LOGIN = true; // UV flag handling in FIDO2/WebAuthn - defaults to false to allow iOS logins // true = required // false = preferred // string 'required' 'preferred' 'discouraged' $WEBAUTHN_UV_FLAG_REGISTER = false; $WEBAUTHN_UV_FLAG_LOGIN = false; $WEBAUTHN_USER_PRESENT_FLAG = true; $FIDO2_UV_FLAG_REGISTER = 'preferred'; $FIDO2_UV_FLAG_LOGIN = 'preferred'; // iOS ignores the key via NFC if required - known issue $FIDO2_USER_PRESENT_FLAG = true; $FIDO2_FORMATS = array('apple', 'android-key', 'android-safetynet', 'fido-u2f', 'none', 'packed', 'tpm'); // Set visible Rspamd maps in mailcow UI, do not change unless you know what you are doing $RSPAMD_MAPS = array( 'regex' => array( 'Header-From: Blacklist' => 'global_mime_from_blacklist.map', 'Header-From: Whitelist' => 'global_mime_from_whitelist.map', 'Envelope Sender Blacklist' => 'global_smtp_from_blacklist.map', 'Envelope Sender Whitelist' => 'global_smtp_from_whitelist.map', 'Recipient Blacklist' => 'global_rcpt_blacklist.map', 'Recipient Whitelist' => 'global_rcpt_whitelist.map', 'Fishy TLDS (only fired in combination with bad words)' => 'fishy_tlds.map', 'Bad Words (only fired in combination with fishy TLDs)' => 'bad_words.map', 'Bad Words DE (only fired in combination with fishy TLDs)' => 'bad_words_de.map', 'Bad Languages' => 'bad_languages.map', 'Bulk Mail Headers' => 'bulk_header.map', 'Bad (Junk) Mail Headers' => 'bad_header.map', 'Monitoring Hosts' => 'monitoring_nolog.map' ) ); $IMAPSYNC_OPTIONS = array( 'whitelist' => array( 'authmech1', 'authmech2', 'authuser1', 'authuser2', 'debugcontent', 'disarmreadreceipts', 'logdir', 'debugcrossduplicates', 'maxsize', 'minsize', 'minage', 'search', 'noabletosearch', 'pidfile', 'pidfilelocking', 'search1', 'search2', 'sslargs1', 'sslargs2', 'syncduplicates', 'usecache', 'synclabels', 'truncmess', 'domino2', 'expunge1', 'filterbuggyflags', 'justconnect', 'justfolders', 'maxlinelength', 'useheader', 'noabletosearch1', 'nolog', 'prefix1', 'prefix2', 'sep1', 'sep2', 'nofoldersizesatend', 'justfoldersizes', 'proxyauth1', 'skipemptyfolders', 'include', 'subfolder1', 'subscribed', 'subscribe', 'debug', 'debugimap2', 'domino1', 'exchange1', 'exchange2', 'justlogin', 'keepalive1', 'keepalive2', 'noabletosearch2', 'noexpunge2', 'noresyncflags', 'nossl1', 'nouidexpunge2', 'syncinternaldates', 'idatefromheader', 'useuid', 'debugflags', 'debugimap', 'delete1emptyfolders', 'delete2folders', 'gmail2', 'office1', 'testslive6', 'debugimap1', 'errorsmax', 'tests', 'gmail1', 'maxmessagespersecond', 'maxbytesafter', 'maxsleep', 'abort', 'resyncflags', 'resynclabels', 'syncacls', 'nosyncacls', 'nousecache', 'office2', 'testslive', 'debugmemory', 'exitwhenover', 'noid', 'noexpunge1', 'authmd51', 'logfile', 'proxyauth2', 'domain1', 'domain2', 'oauthaccesstoken1', 'oauthaccesstoken2', 'oauthdirect1', 'oauthdirect2', 'folder', 'folderrec', 'folderfirst', 'folderlast', 'nomixfolders', 'authmd52', 'debugfolders', 'nossl2', 'ssl2', 'tls2', 'notls2', 'debugssl', 'notls1', 'inet4', 'inet6', 'log', 'showpasswords' ), 'blacklist' => array( 'skipmess', 'delete2foldersonly', 'delete2foldersbutnot', 'regexflag', 'regexmess', 'pipemess', 'regextrans2', 'maxlinelengthcmd' ) );