* Update docs for DNS settings of the services which need its CNAME record by default - Buscarron - Go-NEB; fix a line on the instruction as well - wsproxy - Cinny - Element Web - Hydrogen - SchildiChat Web - Dimension - Etherpad - Jitsi - ntfy - Grafana - rageshake - Sygnal Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs for DNS settings of the services which do not need its CNAME record by default - matrix-alertmanager-receiver - Honoroit - maubot - Heisenbridge - Cactus Comments - Matrix Authentication Service - matrix-registration - Sliding Sync proxy - Synapse Admin - synapse-usage-exporter Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs for DNS settings: ma1sd Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs for DNS settings: Email2Matrix Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs for DNS settings: Postmoogle Remove the table from configuring-dns.md altogether Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs for Cinny and Dimension: adopt the common note Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> * Update docs/configuring-dns.md: add "Note" to the line on using Cloudflare DNS Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> --------- Signed-off-by: Suguru Hirahara <acioustick@noreply.codeberg.org> Co-authored-by: Suguru Hirahara <acioustick@noreply.codeberg.org>
4.9 KiB
Setting up Postmoogle email bridging (optional)
Note: email bridging can also happen via the email2matrix bridge supported by the playbook.
The playbook can install and configure Postmoogle for you.
Postmoogle is a bridge you can use to have its bot user forward emails to Matrix rooms. It runs an SMTP email server and allows you to assign mailbox addresses to the rooms.
See the project's documentation to learn what it does and why it might be useful to you.
Prerequisites
Open the following ports on your server to be able to receive incoming emails:
25/tcp
: SMTP587/tcp
: Submission (TLS-encrypted SMTP)
If you don't open these ports, you will still be able to send emails, but not receive any.
These port numbers are configurable via the matrix_postmoogle_smtp_host_bind_port
and matrix_postmoogle_submission_host_bind_port
variables, but other email servers will try to deliver on these default (standard) ports, so changing them is of little use.
Adjusting DNS records
To make Postmoogle enable its email sending features, you need to configure MX and TXT (SPF, DMARC, and DKIM) records. See the table below for values which need to be specified.
Type | Host | Priority | Weight | Port | Target |
---|---|---|---|---|---|
MX | matrix |
10 | 0 | - | matrix.example.com |
TXT | matrix |
- | - | - | v=spf1 ip4:matrix-server-IP -all |
TXT | _dmarc.matrix |
- | - | - | v=DMARC1; p=quarantine; |
TXT | postmoogle._domainkey.matrix |
- | - | - | get it from !pm dkim |
Note: the DKIM record can be retrieved after configuring and installing the bridge's bot.
Adjusting the playbook configuration
Add the following configuration to your inventory/host_vars/matrix.example.com/vars.yml
file:
matrix_postmoogle_enabled: true
# Uncomment and adjust this part if you'd like to use a username different than the default
# matrix_postmoogle_login: postmoogle
# Generate a strong password for the bot. You can create one with a command like `pwgen -s 64 1`.
matrix_postmoogle_password: PASSWORD_FOR_THE_BOT
# Uncomment to add one or more admins to this bridge:
#
# matrix_postmoogle_admins:
# - '@yourAdminAccount:{{ matrix_domain }}'
#
# … unless you've made yourself an admin of all bots/bridges like this:
#
# matrix_admin: '@yourAdminAccount:{{ matrix_domain }}'
Installing
After configuring the playbook, run it with playbook tags as below:
ansible-playbook -i inventory/hosts setup.yml --tags=setup-all,ensure-matrix-users-created,start
Notes:
-
The
ensure-matrix-users-created
playbook tag makes the playbook automatically create a user account of the bridge's bot. -
The shortcut commands with the
just
program are also available:just install-all
orjust setup-all
just install-all
is useful for maintaining your setup quickly (2x-5x faster thanjust setup-all
) when its components remain unchanged. If you adjust yourvars.yml
to remove other components, you'd need to runjust setup-all
, or these components will still remain installed. -
If you change the bridge's bot password (
matrix_postmoogle_password
in yourvars.yml
file) subsequently, the bot user's credentials on the homeserver won't be updated automatically. If you'd like to change the bot user's password, use a tool like synapse-admin to change it, and then updatematrix_postmoogle_password
to let the bot know its new password.
Usage
To use the bridge, invite the @postmoogle:example.com
bot user into a room you want to use as a mailbox.
Then send !pm mailbox NAME
to expose this Matrix room as an inbox with the email address NAME@matrix.example.com
. Emails sent to that email address will be forwarded to the room.
Send !pm help
to the bot in the room to see the available commands.
You can also refer to the upstream documentation.
Debug/Logs
As with all other services, you can find their logs in systemd-journald by running something like journalctl -fu matrix-postmoogle
The default logging level for this bridge is INFO
, but you can increase it to DEBUG
with the following additional configuration:
matrix_postmoogle_loglevel: 'DEBUG'