2022-11-24 17:23:53 +02:00
{% call macros.panel("info", "Step 1 - Initial configuration") %}
2020-03-08 01:42:38 +02:00
< p > Before starting, some variables must be set.< / p >
2018-10-16 15:12:42 +02:00
< div class = "form-group" >
2019-01-16 21:01:09 +02:00
< label > Mailu storage path: < / label >
2018-10-17 14:11:55 +02:00
<!-- Validates path -->
< input class = "form-control" type = "text" name = "root" value = "/mailu" required pattern = "^/[-_A-Za-z0-9]+(/[-_A-Za-z0-9]*)*" >
2018-10-16 15:12:42 +02:00
< / div >
2020-03-08 01:42:38 +02:00
< p > In the following sections we need to set the postmaster address. This is a combination of the < i > postmaster< / i > local part and the < i > main mail domain< / i > .
The < i > main mail domain< / i > is also used as < / i > "server display name"< / i > . This is the way the SMTP server identifies itself when connecting to others.
2018-10-19 10:57:02 +02:00
The Postmaster will get an e-mail address < postmaster> @< main_domain> . This address will receive the DMARC "rua" and "ruf" reports.
Or in plain english: if receivers start to classify your mail as spam, this postmaster will be informed.< / p >
2018-10-16 15:12:42 +02:00
< div class = "form-group" >
2018-10-19 10:57:02 +02:00
< label >
Main mail domain and server display name.
< / label >
2018-10-17 14:11:55 +02:00
<!-- Validates domain name -->
2020-03-08 01:42:38 +02:00
< input class = "form-control" type = "text" name = "domain" placeholder = "e.g. mailu.io"
2018-10-17 14:11:55 +02:00
required pattern="^([a-z0-9]+(-[a-z0-9]+)*\.)+[a-z]{2,}$">
2018-10-16 15:12:42 +02:00
< / div >
< div class = "form-group" >
2018-10-19 10:57:02 +02:00
< label > Postmaster local part< / label >
2018-10-17 14:11:55 +02:00
< input class = "form-control" type = "text" name = "postmaster" value = "admin" required >
2018-10-16 15:12:42 +02:00
< / div >
< div class = "form-group" >
2019-01-16 21:01:09 +02:00
< label > Choose how you wish to handle security < a href = "https://mailu.io/{{ version }}/compose/setup.html#tls-certificates" > TLS certificates< / a > < / label >
2018-10-16 15:12:42 +02:00
< br / >
2018-10-18 16:23:25 +02:00
< select class = "btn btn-primary dropdown-toggle" name = "tls_flavor" >
2018-10-16 15:12:42 +02:00
{% for tlsflavor in ["letsencrypt", "cert", "notls", "mail", "mail-letsencrypt"] %}
< option value = "{{ tlsflavor }}" > {{ tlsflavor }}< / option >
{% endfor %}
< / select >
< / div >
< div class = "form-group" >
2023-02-09 12:32:10 +02:00
< label > Authentication rate limit per IP for failed login attempts on unique non-existing accounts (password spraying counter-measure)< / label >
2020-02-09 18:38:18 +02:00
<!-- Validates number input only -->
2023-02-09 12:29:55 +02:00
< p > < input class = "form-control" style = "width: 9%; display: inline;" type = "number" name = "auth_ratelimit_ip" value = "5" required > / hour
2021-09-24 12:57:17 +02:00
< / p >
< / div >
< div class = "form-group" >
2021-09-24 13:35:41 +02:00
< label > Authentication rate limit per user< / label >
2021-09-24 12:57:17 +02:00
<!-- Validates number input only -->
< p > < input class = "form-control" style = "width: 9%; display: inline;" type = "number" name = "auth_ratelimit_user"
value="100" required > / day
2020-02-09 18:38:18 +02:00
< / p >
2018-10-16 15:12:42 +02:00
< / div >
2021-08-08 09:21:14 +02:00
< div class = "form-group" >
< label > Outgoing message rate limit (per user)< / label >
<!-- Validates number input only -->
2021-08-18 17:01:10 +02:00
< p > < input class = "form-control" style = "width: 7%; display: inline;" type = "number" name = "message_ratelimit_pd" value = "200" required > / day
2021-08-08 09:21:14 +02:00
< / p >
< / div >
2018-10-16 15:12:42 +02:00
< div class = "form-check form-check-inline" >
< label class = "form-check-label" >
< input class = "form-check-input" type = "checkbox" name = "disable_statistics" value = "True" >
Opt-out of statistics
< / label >
< / div >
< div class = "form-group" >
< label > Website name< / label >
2018-10-17 14:11:55 +02:00
< input class = "form-control" type = "text" name = "site_name" value = "Mailu" required >
2018-10-16 15:12:42 +02:00
< / div >
< div class = "form-group" >
< label > Linked Website URL< / label >
2018-10-17 14:11:55 +02:00
<!-- Validates url with or without https:// -->
< input class = "form-control" type = "url" name = "website" value = "https://mailu.io" required
2019-01-17 11:13:27 +02:00
pattern="^(https?://)?([a-zA-Z0-9]([a-zA-ZäöüÄÖÜ0-9\-]{0,61}[a-zA-Z0-9])?\.)+[a-zA-Z]{2,}$">
2018-10-16 15:12:42 +02:00
< / div >
2018-10-19 10:45:55 +02:00
< p > The admin interface is the main Mailu-specific bit, it provides tools to
manage your email domains, users, etc.< / p >
< div class = "form-group" >
2022-12-19 12:53:52 +02:00
< input type = "checkbox" name = "admin_enabled" value = "true" id = "admin" checked >
2018-10-26 15:50:59 +02:00
< label > Enable the admin UI (and path to the admin UI)< / label >
< input class = "form-control" type = "text" name = "admin_path" id = "admin_path" style = "display: none" >
2018-10-19 10:45:55 +02:00
< / div >
2023-01-25 17:26:10 +02:00
< p > The API interface is a RESTful API for changing the Mailu configuration.
Anything that can be configured via the Mailu web administration interface,
can also be configured via the RESTful API. For enabling the API, an API token must be configured.
It is not possible to use the API without an API token.< / p >
< div class = "form-group" >
2023-01-31 14:37:25 +02:00
< input type = "checkbox" name = "api_enabled" value = "true" id = "api_enabled" >
2023-01-25 17:26:10 +02:00
< label > Enable the API (and path to the API)< / label >
< input class = "form-control" type = "text" name = "api_path" id = "api_path" style = "display: none" >
< label name = "api_token_label" id = "api_token_label" > API token< / label >
2023-01-31 14:37:25 +02:00
< input class = "form-control" type = "text" name = "api_token" id = "api_token" style = "display: none" value = "{{ secret(32) }}" >
2023-01-25 17:26:10 +02:00
< / div >
2021-07-22 16:43:03 +02:00
< script src = "https://ajax.googleapis.com/ajax/libs/jquery/3.6.0/jquery.min.js" > < / script >
2018-10-26 15:50:59 +02:00
2018-11-07 16:41:11 +02:00
< script type = "text/javascript" src = "{{ url_for('static', filename='render.js') }}" > < / script >
2018-10-26 15:50:59 +02:00
2018-10-16 15:12:42 +02:00
{% endcall %}