68 lines
1.7 KiB
YAML
68 lines
1.7 KiB
YAML
services:
|
|
postgres:
|
|
image: postgres:18-alpine
|
|
environment:
|
|
POSTGRES_USER: imap
|
|
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
|
|
POSTGRES_DB: imapcopier
|
|
volumes:
|
|
- pgdata:/var/lib/postgresql
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U imap"]
|
|
interval: 5s
|
|
timeout: 3s
|
|
retries: 5
|
|
networks:
|
|
- imap-copier
|
|
|
|
app:
|
|
build: .
|
|
environment:
|
|
DATABASE_URL: postgres://imap:${POSTGRES_PASSWORD}@postgres:5432/imapcopier?sslmode=disable
|
|
AUTH_USER: ${AUTH_USER}
|
|
AUTH_PASS: ${AUTH_PASS}
|
|
ENC_KEY: ${ENC_KEY}
|
|
SESSION_SECRET: ${SESSION_SECRET}
|
|
WORKER_CONCURRENCY: ${WORKER_CONCURRENCY:-4}
|
|
depends_on:
|
|
postgres:
|
|
condition: service_healthy
|
|
networks:
|
|
- imap-copier
|
|
|
|
caddy:
|
|
image: caddy:2-alpine
|
|
labels:
|
|
- "traefik.enable=true"
|
|
- "traefik.http.routers.imap-copier.rule=Host(`imap-copier.amegahost.kz`)"
|
|
- "traefik.http.routers.imap-copier.entrypoints=https"
|
|
- "traefik.http.routers.imap-copier.tls=true"
|
|
- "traefik.http.routers.imap-copier.tls.certresolver=letsEncrypt"
|
|
- "traefik.http.services.imap-copier-service.loadbalancer.server.port=80"
|
|
- "traefik.docker.network=webproxy"
|
|
expose:
|
|
- "${HTTP_PORT:-80}"
|
|
- "443"
|
|
environment:
|
|
DOMAIN: ${DOMAIN:-}
|
|
ACME_EMAIL: ${ACME_EMAIL:-}
|
|
volumes:
|
|
- ./Caddyfile:/etc/caddy/Caddyfile:ro
|
|
- caddy_data:/data
|
|
- caddy_config:/config
|
|
depends_on:
|
|
- app
|
|
networks:
|
|
- imap-copier
|
|
- webproxy
|
|
|
|
volumes:
|
|
pgdata:
|
|
caddy_data:
|
|
caddy_config:
|
|
|
|
networks:
|
|
imap-copier:
|
|
name: imap-copier
|
|
webproxy:
|
|
external: true |