2021-05-01 23:00:37 +01:00
|
|
|
version: "2.3"
|
|
|
|
|
|
|
|
services:
|
|
|
|
vaultwarden:
|
2023-08-01 13:51:06 +01:00
|
|
|
image: vaultwarden/server:1.29.1-alpine
|
2021-05-01 23:00:37 +01:00
|
|
|
restart: unless-stopped
|
|
|
|
user: "{{ docker_user.id }}:{{ docker_user.id }}"
|
|
|
|
volumes:
|
|
|
|
- "{{ app_data_dir }}/vaultwarden/:/data"
|
|
|
|
depends_on:
|
|
|
|
- db
|
|
|
|
labels:
|
|
|
|
- traefik.enable=true
|
|
|
|
|
2023-07-10 13:41:56 +01:00
|
|
|
- traefik.http.routers.vaultwarden.rule=Host(`vaultwarden.jakehoward.tech`)
|
|
|
|
- traefik.http.routers.vaultwarden.service=vaultwarden
|
|
|
|
- traefik.http.services.vaultwarden.loadbalancer.server.port=80
|
2021-05-01 23:00:37 +01:00
|
|
|
|
|
|
|
- traefik.http.middlewares.vaultwarden-ratelimit.ratelimit.average=5
|
|
|
|
- traefik.http.middlewares.vaultwarden-ratelimit.ratelimit.burst=1000
|
|
|
|
|
2023-07-10 13:41:56 +01:00
|
|
|
- traefik.http.routers.vaultwarden.middlewares=vaultwarden-ratelimit
|
2021-05-01 23:00:37 +01:00
|
|
|
environment:
|
|
|
|
- SIGNUPS_ALLOWED=false
|
2021-05-18 22:18:05 +01:00
|
|
|
- DOMAIN=https://vaultwarden.jakehoward.tech
|
2021-05-01 23:00:37 +01:00
|
|
|
- SHOW_PASSWORD_HINT=false
|
2021-05-18 22:18:05 +01:00
|
|
|
- DATABASE_URL=postgres://vaultwarden:{{ vaultwarden_database_password }}@db/vaultwarden
|
2021-05-01 23:00:37 +01:00
|
|
|
- INVITATIONS_ALLOWED=false
|
2021-05-18 22:18:05 +01:00
|
|
|
- ROCKET_WORKERS={{ ansible_processor_nproc // 2 }}
|
2022-01-15 23:44:06 +00:00
|
|
|
networks:
|
|
|
|
- default
|
|
|
|
- traefik
|
2021-05-01 23:00:37 +01:00
|
|
|
|
|
|
|
db:
|
2021-12-22 15:33:40 +00:00
|
|
|
image: postgres:14-alpine
|
2021-05-01 23:00:37 +01:00
|
|
|
restart: unless-stopped
|
|
|
|
volumes:
|
2023-06-15 21:18:50 +01:00
|
|
|
- /mnt/speed/dbs/postgres/vaultwarden/:/var/lib/postgresql/data
|
2021-05-01 23:00:37 +01:00
|
|
|
environment:
|
2021-05-18 22:18:05 +01:00
|
|
|
- POSTGRES_PASSWORD={{ vaultwarden_database_password }}
|
|
|
|
- POSTGRES_USER=vaultwarden
|
2022-01-15 23:44:06 +00:00
|
|
|
|
|
|
|
networks:
|
|
|
|
traefik:
|
|
|
|
external: true
|