-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcompose.yaml
More file actions
125 lines (119 loc) · 4.58 KB
/
compose.yaml
File metadata and controls
125 lines (119 loc) · 4.58 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
services:
api:
image: ${IMAGES_PREFIX:-}-api
depends_on:
- database
restart: unless-stopped
environment:
PWA_UPSTREAM: pwa:3000
SERVER_NAME: ${SERVER_NAME:-localhost}, api:80
MERCURE_PUBLISHER_JWT_KEY: ${CADDY_MERCURE_JWT_SECRET:-!ChangeThisMercureHubJWTSecretKey!}
MERCURE_SUBSCRIBER_JWT_KEY: ${CADDY_MERCURE_JWT_SECRET:-!ChangeThisMercureHubJWTSecretKey!}
TRUSTED_PROXIES: ${TRUSTED_PROXIES:-127.0.0.0/8,10.0.0.0/8,172.16.0.0/12,192.168.0.0/16}
TRUSTED_HOSTS: ${TRUSTED_HOSTS:-^${SERVER_NAME:-example\.com|localhost}|api}
MERCURE_URL: ${CADDY_MERCURE_URL:-http://api/.well-known/mercure}
MERCURE_PUBLIC_URL: ${CADDY_MERCURE_PUBLIC_URL:-https://${SERVER_NAME:-localhost}:${HTTPS_PORT:-443}/.well-known/mercure}
MERCURE_JWT_SECRET: ${CADDY_MERCURE_JWT_SECRET:-!ChangeThisMercureHubJWTSecretKey!}
CORS_ALLOW_ORIGIN: ^(https?:\/\/(pwa|localhost|127\.0\.0\.1)(:[0-9]+)?|chrome-extension:\/\/fbmkmdnlhacefjljljlbhkodfmfkijdh|moz-extension:\/\/(774f040e-d814-4323-902a-dc0d33480bf7|7b7889d2-3187-4203-9272-f0dcc74dd61b))$
NODE_MODE: php
volumes:
- caddy_data:/data
- caddy_config:/config
- /tmp/downloader-downloads:/downloads
ports:
# HTTP
- target: 80
published: ${HTTP_PORT:-80}
protocol: tcp
# HTTPS
- target: 443
published: ${HTTPS_PORT:-443}
protocol: tcp
# HTTP/3
- target: 443
published: ${HTTP3_PORT:-443}
protocol: udp
#command: composer install && wait-for-it rabbitmq:5672 --strict -- frankenphp run --config /etc/frankenphp/Caddyfile --watch
healthcheck:
test: curl --insecure --fail https://localhost/docs || exit 1
timeout: 5s
retries: 5
start_period: 60s
worker:
image: ${IMAGES_PREFIX:-}-api # Actually worker, but it uses the same image as php
depends_on:
- api
- database
restart: unless-stopped
environment:
MERCURE_PUBLISHER_JWT_KEY: ${CADDY_MERCURE_JWT_SECRET:-!ChangeThisMercureHubJWTSecretKey!}
MERCURE_SUBSCRIBER_JWT_KEY: ${CADDY_MERCURE_JWT_SECRET:-!ChangeThisMercureHubJWTSecretKey!}
TRUSTED_PROXIES: ${TRUSTED_PROXIES:-127.0.0.0/8,10.0.0.0/8,172.16.0.0/12,192.168.0.0/16}
TRUSTED_HOSTS: ${TRUSTED_HOSTS:-^${SERVER_NAME:-example\.com|localhost}|api}
MERCURE_URL: ${CADDY_MERCURE_URL:-http://api/.well-known/mercure}
MERCURE_PUBLIC_URL: ${CADDY_MERCURE_PUBLIC_URL:-https://${SERVER_NAME:-localhost}:${HTTPS_PORT:-443}/.well-known/mercure}
MERCURE_JWT_SECRET: ${CADDY_MERCURE_JWT_SECRET:-!ChangeThisMercureHubJWTSecretKey!}
NODE_MODE: worker
volumes:
- /tmp/downloader-downloads:/downloads
command: bin/console messenger:consume async --limit=100 -vv
healthcheck:
test: ["CMD", "true"]
timeout: 5s
retries: 10
start_period: 60s
pwa:
image: ${IMAGES_PREFIX:-}-pwa
environment:
NEXT_PUBLIC_ENTRYPOINT: http://api
healthcheck:
test: curl -f http://localhost:3000 || exit 1
timeout: 5s
retries: 5
start_period: 60s
###> doctrine/doctrine-bundle ###
database:
image: postgres:${POSTGRES_VERSION:-16}-alpine
environment:
- POSTGRES_DB=${POSTGRES_DB:-app}
# You should definitely change the password in production
- POSTGRES_PASSWORD=${POSTGRES_PASSWORD:-!ChangeMe!}
- POSTGRES_USER=${POSTGRES_USER:-app}
healthcheck:
test: ["CMD", "pg_isready", "-d", "${POSTGRES_DB:-app}", "-U", "${POSTGRES_USER:-app}"]
timeout: 5s
retries: 5
start_period: 60s
volumes:
- database_data:/var/lib/postgresql/data:rw
# You may use a bind-mounted host directory instead, so that it is harder to accidentally remove the volume and lose all your data!
# - ./api/docker/db/data:/var/lib/postgresql/data:rw
###< doctrine/doctrine-bundle ###
gallery-dl:
image: qx6ghqkz/gallery-dl-server:latest
container_name: gallery-dl
ports:
- "9080:9080"
environment:
- "UID=1000"
- "GID=1000"
volumes:
- "./docker/gallery-dl/config:/config"
- "./docker/gallery-dl/downloads:/gallery-dl"
restart: on-failure
profiles:
- web-downloader
# Mercure is installed as a Caddy module, prevent the Flex recipe from installing another service
###> symfony/mercure-bundle ###
###< symfony/mercure-bundle ###
configs:
rabbitmq-plugins:
content: "[rabbitmq_management]."
volumes:
caddy_data:
caddy_config:
###> doctrine/doctrine-bundle ###
database_data:
###< doctrine/doctrine-bundle ###
###> symfony/mercure-bundle ###
###< symfony/mercure-bundle ###