security hardening, team invites, granular locking, view counts, board subscriptions, scheduled changelog, mentions, recovery codes, accessibility and hover states

This commit is contained in:
2026-03-21 17:37:01 +02:00
parent f07eddf29e
commit 5ba25fb956
142 changed files with 30397 additions and 2287 deletions

View File

@@ -1,41 +1,32 @@
version: "3.8"
name: echoboard
services:
app:
build: .
ports:
- "${PORT:-3000}:3000"
environment:
DATABASE_URL: postgresql://echoboard:${DB_PASSWORD}@db:5432/echoboard
APP_MASTER_KEY: ${APP_MASTER_KEY}
APP_BLIND_INDEX_KEY: ${APP_BLIND_INDEX_KEY}
TOKEN_SECRET: ${TOKEN_SECRET}
JWT_SECRET: ${JWT_SECRET}
ALTCHA_HMAC_KEY: ${ALTCHA_HMAC_KEY}
WEBAUTHN_RP_NAME: ${WEBAUTHN_RP_NAME:-Echoboard}
WEBAUTHN_RP_ID: ${WEBAUTHN_RP_ID}
WEBAUTHN_ORIGIN: ${WEBAUTHN_ORIGIN}
VAPID_PUBLIC_KEY: ${VAPID_PUBLIC_KEY}
VAPID_PRIVATE_KEY: ${VAPID_PRIVATE_KEY}
VAPID_CONTACT: ${VAPID_CONTACT}
NODE_ENV: production
restart: unless-stopped
depends_on:
db:
condition: service_healthy
env_file: .env
environment:
DATABASE_URL: postgresql://echoboard:${POSTGRES_PASSWORD}@db:5432/echoboard
NODE_ENV: production
ports:
- "${PORT:-3000}:${PORT:-3000}"
volumes:
- ./uploads:/app/packages/api/uploads
db:
image: postgres:16-alpine
restart: unless-stopped
environment:
POSTGRES_DB: echoboard
POSTGRES_USER: echoboard
POSTGRES_PASSWORD: ${DB_PASSWORD}
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
POSTGRES_DB: echoboard
volumes:
- pgdata:/var/lib/postgresql/data
- ./data/postgres:/var/lib/postgresql/data
healthcheck:
test: ["CMD-SHELL", "pg_isready -U echoboard"]
interval: 5s
timeout: 3s
retries: 5
volumes:
pgdata: