unoffical wafrn mirror
wafrn.net
atproto
social-network
activitypub
1services:
2 backend: &default_backend
3 build: &default_backend_build
4 context: .
5 dockerfile: packages/backend/Dockerfile
6 # these args configure private env vars for the backend and public env vars for the frontend
7 args: &default_backend_build_args
8 ADMIN_USER: ${ADMIN_USER}
9 ADMIN_EMAIL: ${ADMIN_EMAIL}
10 ADMIN_PASSWORD: ${ADMIN_PASSWORD}
11 JWT_SECRET: ${JWT_SECRET}
12 DOMAIN_NAME: ${DOMAIN_NAME}
13
14 CACHE_DOMAIN: ${CACHE_DOMAIN}
15 MEDIA_DOMAIN: ${MEDIA_DOMAIN}
16
17 SMTP_HOST: ${SMTP_HOST}
18 SMTP_USER: ${SMTP_USER}
19 SMTP_PORT: ${SMTP_PORT}
20 SMTP_PASSWORD: ${SMTP_PASSWORD}
21 SMTP_FROM: ${SMTP_FROM}
22
23 POSTGRES_USER: ${POSTGRES_USER}
24 POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
25 POSTGRES_DBNAME: ${POSTGRES_DBNAME}
26
27 WEBPUSH_EMAIL: ${WEBPUSH_EMAIL}
28 WEBPUSH_PRIVATE: ${WEBPUSH_PRIVATE}
29 WEBPUSH_PUBLIC: ${WEBPUSH_PUBLIC}
30
31 ENABLE_BSKY: ${ENABLE_BSKY}
32 PDS_DOMAIN_NAME: ${PDS_DOMAIN_NAME}
33 PDS_JWT_SECRET: ${PDS_JWT_SECRET}
34 PDS_ADMIN_PASSWORD: ${PDS_ADMIN_PASSWORD}
35
36 USE_WORKERS: false
37 LOG_SQL_QUERIES: ${LOG_SQL_QUERIES:-}
38 UPLOAD_LIMIT: ${UPLOAD_LIMIT:-}
39 POSTS_PER_PAGE: ${POSTS_PER_PAGE:-}
40 LOG_LEVEL: ${LOG_LEVEL:-}
41 BLOCKLIST_URI: ${BLOCKLIST_URI:-}
42 FRONTEND_PATH: ${FRONTEND_PATH:-}
43 DISABLE_REQUIRE_SEND_EMAIL: ${DISABLE_REQUIRE_SEND_EMAIL:-}
44 BLOCKED_IPS: ${BLOCKED_IPS:-}
45 REVIEW_REGISTRATIONS: ${REVIEW_REGISTRATIONS:-}
46 IGNORE_BLOCK_HOSTS: ${IGNORE_BLOCK_HOSTS:-}
47
48 FRONTEND_LOGO: ${FRONTEND_LOGO:-}
49 FRONTEND_API_URL: ${FRONTEND_API_URL:-}
50 FRONTEND_MEDIA_URL: ${FRONTEND_MEDIA_URL:-}
51 FRONTEND_CACHE_URL: ${FRONTEND_CACHE_URL:-}
52 FRONTEND_CACHE_BACKUP_URLS: ${FRONTEND_CACHE_BACKUP_URLS:-}
53 FRONTEND_SHORTEN_POSTS: ${FRONTEND_SHORTEN_POSTS:-}
54 FRONTEND_DISABLE_PWA: ${FRONTEND_DISABLE_PWA:-}
55 FRONTEND_MAINTENANCE: ${FRONTEND_MAINTENANCE:-}
56 FRONTEND_SHORT_TITLE: ${FRONTEND_SHORT_TITLE:-}
57 FRONTEND_LONG_TITLE: ${FRONTEND_LONG_TITLE:-}
58 FRONTEND_DESCRIPTION: ${FRONTEND_DESCRIPTION:-}
59 depends_on:
60 db:
61 condition: service_started
62 redis:
63 condition: service_started
64 frontend:
65 condition: service_started
66 migration:
67 condition: service_completed_successfully
68 restart: unless-stopped
69 environment:
70 - NODE_ENV=production
71 volumes:
72 - ./packages/backend/uploads:/app/packages/backend/uploads
73 - ./packages/backend/cache:/app/packages/backend/cache
74 - frontend:/app/packages/frontend:ro
75
76 migration:
77 <<: *default_backend
78 depends_on:
79 db:
80 condition: service_started
81 redis:
82 condition: service_started
83 frontend:
84 condition: service_started
85 restart: no
86 command: "npm exec tsx migrate.ts init-container"
87
88 frontend:
89 restart: unless-stopped
90 build:
91 context: .
92 dockerfile: packages/frontend/Dockerfile
93 args:
94 DOMAIN_NAME: ${DOMAIN_NAME}
95 PDS_DOMAIN_NAME: ${PDS_DOMAIN_NAME}
96 CACHE_DOMAIN: ${CACHE_DOMAIN}
97 MEDIA_DOMAIN: ${MEDIA_DOMAIN}
98 ACME_EMAIL: ${ACME_EMAIL}
99 FRONTEND_SHORT_TITLE: ${FRONTEND_SHORT_TITLE:-}
100 FRONTEND_LONG_TITLE: ${FRONTEND_LONG_TITLE:-}
101 FRONTEND_DESCRIPTION: ${FRONTEND_DESCRIPTION:-}
102 CACHE_HOST: "cache:9000"
103 ports:
104 - 80:80
105 - 443:443
106 volumes:
107 - "caddy:/data"
108 - "frontend:/var/www/html/frontend"
109 - ./packages/backend/uploads:/var/www/html/uploads
110 - ./packages/caddy:/etc/caddy/config
111
112 db:
113 image: postgres:17
114 restart: unless-stopped
115 shm_size: '2gb'
116 environment:
117 POSTGRES_USER: ${POSTGRES_USER}
118 POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
119 POSTGRES_DB: ${POSTGRES_DBNAME}
120 volumes:
121 - dbpg:/var/lib/postgresql/data
122
123 adminer:
124 image: adminer
125 restart: unless-stopped
126
127 redis:
128 image: redis:7.2.4
129 restart: unless-stopped
130 volumes:
131 - redis:/data
132
133 pds:
134 image: ghcr.io/bluesky-social/pds:0.4
135 restart: unless-stopped
136 profiles:
137 - bluesky
138 environment:
139 PDS_HOSTNAME: ${PDS_DOMAIN_NAME}
140 PDS_JWT_SECRET: ${PDS_JWT_SECRET}
141 PDS_ADMIN_PASSWORD: ${PDS_ADMIN_PASSWORD}
142 PDS_PLC_ROTATION_KEY_K256_PRIVATE_KEY_HEX: ${PDS_PLC_ROTATION_KEY_K256_PRIVATE_KEY_HEX}
143 PDS_DATA_DIRECTORY: /pds
144 PDS_BLOBSTORE_DISK_LOCATION: /pds/blocks
145 PDS_BLOB_UPLOAD_LIMIT: 52428800
146 PDS_DID_PLC_URL: "https://plc.directory"
147 PDS_BSKY_APP_VIEW_URL: "https://api.bsky.app"
148 PDS_BSKY_APP_VIEW_DID: "did:web:api.bsky.app"
149 PDS_REPORT_SERVICE_URL: "https://mod.bsky.app"
150 PDS_REPORT_SERVICE_DID: "did:plc:ar7c4by46qjdydhdevvrndac"
151 PDS_CRAWLERS: "https://bsky.network, https://atproto.africa"
152 PDS_EMAIL_SMTP_URL: "smtps://${SMTP_USER}:${SMTP_PASSWORD}@${SMTP_HOST}:${SMTP_PORT}"
153 PDS_EMAIL_FROM_ADDRESS: "${SMTP_USER}"
154 LOG_ENABLED: true
155 volumes:
156 - pds:/pds
157
158 pds_worker:
159 <<: *default_backend
160 profiles:
161 - bluesky
162 command: "npm exec tsx atproto.ts"
163
164 cache:
165 <<: *default_backend
166
167 workers:
168 <<: *default_backend
169 build:
170 <<: *default_backend_build
171 args:
172 <<: *default_backend_build_args
173 USE_WORKERS: true
174 deploy:
175 mode: replicated
176 replicas: 3
177
178volumes:
179 dbpg:
180 caddy:
181 pds:
182 frontend:
183 redis: