mirror of
https://github.com/chatmail/relay.git
synced 2026-05-18 20:08:21 +00:00
docker: add Traefik support
USE_FOREIGN_CERT_MANAGER existed in compose/example.env but was never read by any code. This wires it up end-to-end based on PR 662. - Preliminarily add config options for this, and skip AcmetoolDeployer if set. - Add Traefik integration in docker/docker-compose-traefik.yaml, with traefik-certs-dumper - post-hook.sh creates fullchain/privkey symlinks for chatmail - Chatmail container uses ports 25/143/465/587/993 directly, Traefik handles 80/443 - docker/traefik/ contains config.yaml and dynamic configs - docker/example-traefik.env for the Traefik setup - rename USE_FOREIGN_CERT_MANAGER to CHATMAIL_NOACME
This commit is contained in:
30
docker/traefik/config.yaml
Normal file
30
docker/traefik/config.yaml
Normal file
@@ -0,0 +1,30 @@
|
||||
log:
|
||||
level: INFO
|
||||
|
||||
entryPoints:
|
||||
web:
|
||||
address: ":80"
|
||||
http:
|
||||
redirections:
|
||||
entryPoint:
|
||||
to: websecure
|
||||
permanent: true
|
||||
websecure:
|
||||
address: ":443"
|
||||
|
||||
providers:
|
||||
docker:
|
||||
endpoint: "unix:///var/run/docker.sock"
|
||||
exposedByDefault: false
|
||||
file:
|
||||
directory: /dynamic/conf
|
||||
watch: true
|
||||
|
||||
certificatesResolvers:
|
||||
letsEncrypt:
|
||||
acme:
|
||||
storage: /data/acme.json
|
||||
caServer: "https://acme-v02.api.letsencrypt.org/directory"
|
||||
tlschallenge: true
|
||||
httpChallenge:
|
||||
entryPoint: web
|
||||
4
docker/traefik/dynamic-configs/insecure.yaml
Normal file
4
docker/traefik/dynamic-configs/insecure.yaml
Normal file
@@ -0,0 +1,4 @@
|
||||
http:
|
||||
serversTransports:
|
||||
insecure:
|
||||
insecureSkipVerify: true
|
||||
12
docker/traefik/post-hook.sh
Normal file
12
docker/traefik/post-hook.sh
Normal file
@@ -0,0 +1,12 @@
|
||||
#!/bin/sh
|
||||
# Post-hook for traefik-certs-dumper: create symlinks from Traefik's
|
||||
# cert dump format to the paths chatmail expects (fullchain, privkey).
|
||||
CERTS_DIR="${CERTS_DIR:-/certs}"
|
||||
|
||||
for dir in "$CERTS_DIR"/*/; do
|
||||
[ -d "$dir" ] || continue
|
||||
cd "$dir"
|
||||
[ -f "certificate.crt" ] && ln -sf certificate.crt fullchain
|
||||
[ -f "privatekey.key" ] && ln -sf privatekey.key privkey
|
||||
cd - > /dev/null
|
||||
done
|
||||
Reference in New Issue
Block a user