{% import "macros.html" as macros %} {% call macros.panel("info", "Step 1 - Download your configuration files") %}
Docker Stack expects a project file, named docker-compose.yml
in a project directory. First create your project directory.
mkdir -p /{{ root }}/{redis,certs,data,dkim,mail,overrides/rspamd,filter,dav,webmail}
Then download the project file. A side configuration file makes it easier to read and check the configuration variables generated by the wizard.
cd {{ root }}
curl {{ url_for('.file', uid=uid, filepath='docker-compose.yml', _external=True) }} > docker-compose.yml
curl {{ url_for('.file', uid=uid, filepath='mailu.env', _external=True) }} > mailu.env
We did not insert any malicious code on purpose in the configurations we distribute, but your download could have been intercepted, or our wizard website could have been compromised, so make sure you check the configuration files before going any further.
When you are done checking them, check them one last time.
{% endcall %} {% call macros.panel("info", "Step 3 - Deploy docker stack") %}To deploy the docker stack use the following commands. For more information about setting up docker swarm nodes read the docker documentation
cd {{ root }}
docker swarm init
docker stack deploy -c docker-compose.yml mailu
docker psdocker stack ps --no-trunc mailudocker stack rm mailudocker exec $(docker ps | grep admin | cut -d ' ' -f1) python manage.py admin {{ postmaster }} {{ domain }} PASSWORD 
Login to the admin interface to change the password for a safe one, at {% if admin_enabled %} one of the hostnames {{ hostnames.split(',')[0] }}{{ admin_path }}. {% else %} http://127.0.0.1:8080 (only directly from the host running docker). {% endif %} And choose the "Update password" option in the left menu.
{% endcall %}