services: frontend: image: git.federspiel.tech/flfeders/fedeo/frontend:dev restart: always environment: - NUXT_PUBLIC_API_BASE=https://app.fedeo.de/backend - NUXT_PUBLIC_PDF_LICENSE=eyJkYXRhIjoiZXlKMElqb2laR1YyWld4dmNHVnlJaXdpWVhaMUlqb3hOemt3TmpNNU9UazVMQ0prYlNJNkltRndjQzVtWldSbGJ5NWtaU0lzSW00aU9pSXpOemt3Wm1Vek5UazBZbVU0TlRRNElpd2laWGh3SWpveE56a3dOak01T1RrNUxDSmtiWFFpT2lKemNHVmphV1pwWXlJc0luQWlPaUoyYVdWM1pYSWlmUT09Iiwic2lnbmF0dXJlIjoicWU4K0ZxQUJDNUp5bEJUU094Vkd5RTJMbk9UNmpyc2EyRStsN2tNNWhkM21KK2ZvVjYwaTFKeFdhZGtqSDRNWXZxQklMc0dpdWh5d2pMbUFjRHZuWGxOcTRMcXFLRm53dzVtaG1LK3lTeDRXbzVaS1loK1VZdFBzWUZjV3oyUHVGMmJraGJrVjJ6RzRlTGtRU09wdmJKY3JUZU1rN0N1VkN6Q1UraHF5T0ZVVXllWnRmaHlmcWswZEFFL0RMR1hvTDFSQXFjNkNkYU9FTDRTdC9Idy9DQnFieTE2aisvT3RxQUlLcy9NWTR6SVk3RTI3bWo4RUx5VjhXNkdXNXhqc0VUVzNKN0RRMUVlb3RhVlNLT29kc3pVRlhUYzVlbHVuSm04ZlcwM1ErMUhtSnpmWGoyS1dwM1dnamJDazZYSHozamFML2lOdUYvZFZNaWYvc2FoR3NnPT0ifQ== networks: - traefik labels: - "traefik.enable=true" - "traefik.docker.network=traefik" - "traefik.port=3000" # Middlewares - "traefik.http.middlewares.fedeo-frontend-redirect-web-secure.redirectscheme.scheme=https" # Web Entrypoint - "traefik.http.routers.fedeo-frontend.middlewares=fedeo-frontend-redirect-web-secure" - "traefik.http.routers.fedeo-frontend.rule=Host(`app.fedeo.de`) && PathPrefix(`/`)" - "traefik.http.routers.fedeo-frontend.entrypoints=web" - "traefik.http.routers.fedeo-frontend.priority=1" # Web Secure Entrypoint - "traefik.http.routers.fedeo-frontend-secure.rule=Host(`app.fedeo.de`) && PathPrefix(`/`)" - "traefik.http.routers.fedeo-frontend-secure.entrypoints=web-secured" # - "traefik.http.routers.fedeo-frontend-secure.tls.certresolver=mytlschallenge" - "traefik.http.routers.fedeo-frontend-secure.priority=1" docs: image: git.federspiel.tech/flfeders/fedeo/docs:dev restart: always networks: - traefik labels: - "traefik.enable=true" - "traefik.docker.network=traefik" - "traefik.port=3000" # Middlewares - "traefik.http.middlewares.fedeo-docs-redirect-web-secure.redirectscheme.scheme=https" - "traefik.http.middlewares.fedeo-docs-strip.stripprefix.prefixes=/docs" # Web Entrypoint - "traefik.http.routers.fedeo-docs.middlewares=fedeo-docs-redirect-web-secure" - "traefik.http.routers.fedeo-docs.rule=Host(`app.fedeo.de`) && PathPrefix(`/docs`)" - "traefik.http.routers.fedeo-docs.entrypoints=web" - "traefik.http.routers.fedeo-docs.priority=120" # Web Secure Entrypoint - "traefik.http.routers.fedeo-docs-secure.rule=Host(`app.fedeo.de`) && PathPrefix(`/docs`)" - "traefik.http.routers.fedeo-docs-secure.entrypoints=web-secured" - "traefik.http.routers.fedeo-docs-secure.tls.certresolver=mytlschallenge" - "traefik.http.routers.fedeo-docs-secure.middlewares=fedeo-docs-strip" - "traefik.http.routers.fedeo-docs-secure.priority=120" backend: image: git.federspiel.tech/flfeders/fedeo/backend:dev restart: always environment: - INFISICAL_CLIENT_ID=a6838bd6-9983-4bf4-9be2-ace830b9abdf - INFISICAL_CLIENT_SECRET=4e3441acc0adbffd324aa50e668a95a556a3f55ec6bb85954e176e35a3392003 - NODE_ENV=production - WEB_PUSH_PUBLIC_KEY=${WEB_PUSH_PUBLIC_KEY:-} - WEB_PUSH_PRIVATE_KEY=${WEB_PUSH_PRIVATE_KEY:-} - WEB_PUSH_SUBJECT=${WEB_PUSH_SUBJECT:-mailto:admin@example.com} - NODE_EXPORTER_URL=${NODE_EXPORTER_URL:-http://node-exporter:9100} - TELEPHONY_ENABLED=${TELEPHONY_ENABLED:-false} - TELEPHONY_ASTERISK_HTTP_URL=${TELEPHONY_ASTERISK_HTTP_URL:-http://asterisk-dev:8088/ws} - TELEPHONY_ASTERISK_WS_URL=${TELEPHONY_ASTERISK_WS_URL:-ws://localhost:8088/ws} - TELEPHONY_SIP_DOMAIN=${TELEPHONY_SIP_DOMAIN:-localhost} - TELEPHONY_TEST_EXTENSION=${TELEPHONY_TEST_EXTENSION:-1001} - TELEPHONY_TEST_PASSWORD=${TELEPHONY_TEST_PASSWORD:-fedeo-test-1001} - TELEPHONY_TEST_EXTENSION_2=${TELEPHONY_TEST_EXTENSION_2:-1002} - TELEPHONY_TEST_PASSWORD_2=${TELEPHONY_TEST_PASSWORD_2:-fedeo-test-1002} - TELEPHONY_ECHO_EXTENSION=${TELEPHONY_ECHO_EXTENSION:-600} - TELEPHONY_EXTERNAL_PROVIDER=${TELEPHONY_EXTERNAL_PROVIDER:-} - TELEPHONY_EXTERNAL_ENABLED=${TELEPHONY_EXTERNAL_ENABLED:-false} - TELEPHONY_EXTERNAL_INBOUND_EXTENSION=${TELEPHONY_EXTERNAL_INBOUND_EXTENSION:-1001} - TELEPHONY_ASTERISK_GENERATED_DIR=${TELEPHONY_ASTERISK_GENERATED_DIR:-/var/lib/fedeo/asterisk/generated} - TELEPHONY_ASTERISK_AMI_HOST=${TELEPHONY_ASTERISK_AMI_HOST:-asterisk-dev} - TELEPHONY_ASTERISK_AMI_PORT=${TELEPHONY_ASTERISK_AMI_PORT:-5038} - TELEPHONY_ASTERISK_AMI_USER=${TELEPHONY_ASTERISK_AMI_USER:-fedeo} - TELEPHONY_ASTERISK_AMI_PASSWORD=${TELEPHONY_ASTERISK_AMI_PASSWORD:-fedeo-ami-dev} volumes: - ./telephony/generated:/var/lib/fedeo/asterisk/generated networks: - traefik labels: - "traefik.enable=true" - "traefik.docker.network=traefik" - "traefik.port=3100" # Middlewares - "traefik.http.middlewares.fedeo-backend-redirect-web-secure.redirectscheme.scheme=https" - "traefik.http.middlewares.fedeo-backend-strip.stripprefix.prefixes=/backend" # Web Entrypoint - "traefik.http.routers.fedeo-backend.middlewares=fedeo-backend-redirect-web-secure" - "traefik.http.routers.fedeo-backend.rule=Host(`app.fedeo.de`) && PathPrefix(`/backend`)" - "traefik.http.routers.fedeo-backend.entrypoints=web" # Web Secure Entrypoint - "traefik.http.routers.fedeo-backend-secure.rule=Host(`app.fedeo.de`) && PathPrefix(`/backend`)" - "traefik.http.routers.fedeo-backend-secure.entrypoints=web-secured" # - "traefik.http.routers.fedeo-backend-secure.tls.certresolver=mytlschallenge" - "traefik.http.routers.fedeo-backend-secure.middlewares=fedeo-backend-strip" node-exporter: image: prom/node-exporter:v1.8.2 restart: unless-stopped command: - --path.procfs=/host/proc - --path.sysfs=/host/sys - --path.rootfs=/rootfs - --collector.filesystem.mount-points-exclude=^/(sys|proc|dev|host|etc)($$|/) pid: host volumes: - /proc:/host/proc:ro - /sys:/host/sys:ro - /:/rootfs:ro,rslave networks: - traefik asterisk-dev: image: ${ASTERISK_IMAGE:-andrius/asterisk:20} restart: unless-stopped profiles: - telephony-dev environment: - TELEPHONY_TELEKOM_ENABLED=${TELEPHONY_TELEKOM_ENABLED:-false} - TELEPHONY_TELEKOM_REGISTRAR=${TELEPHONY_TELEKOM_REGISTRAR:-tel.t-online.de} - TELEPHONY_TELEKOM_SIP_USER=${TELEPHONY_TELEKOM_SIP_USER:-} - TELEPHONY_TELEKOM_AUTH_USER=${TELEPHONY_TELEKOM_AUTH_USER:-} - TELEPHONY_TELEKOM_PASSWORD=${TELEPHONY_TELEKOM_PASSWORD:-} - TELEPHONY_TELEKOM_CALLER_ID=${TELEPHONY_TELEKOM_CALLER_ID:-} - TELEPHONY_TELEKOM_INBOUND_EXTENSION=${TELEPHONY_TELEKOM_INBOUND_EXTENSION:-1001} - TELEPHONY_TELEKOM_OUTBOUND_PREFIX=${TELEPHONY_TELEKOM_OUTBOUND_PREFIX:-0} - TELEPHONY_ASTERISK_EXTERNAL_SIGNALING_ADDRESS=${TELEPHONY_ASTERISK_EXTERNAL_SIGNALING_ADDRESS:-} - TELEPHONY_ASTERISK_EXTERNAL_MEDIA_ADDRESS=${TELEPHONY_ASTERISK_EXTERNAL_MEDIA_ADDRESS:-} - ASTERISK_GENERATED_DIR=/etc/asterisk/generated command: - /bin/sh - -c - /usr/local/bin/render-asterisk-config.sh && asterisk -f volumes: - ./telephony/asterisk:/etc/asterisk - ./telephony/generated:/etc/asterisk/generated - ./telephony/render-asterisk-config.sh:/usr/local/bin/render-asterisk-config.sh:ro ports: - "${TELEPHONY_DEV_WS_PORT:-8088}:8088" - "${TELEPHONY_DEV_AMI_PORT:-5038}:5038" - "${TELEPHONY_DEV_SIP_PORT:-5060}:5060/udp" - "${TELEPHONY_DEV_RTP_MIN_PORT:-10000}-${TELEPHONY_DEV_RTP_MAX_PORT:-10100}:10000-10100/udp" networks: - traefik matrix-db: image: postgres:16-alpine restart: unless-stopped profiles: - matrix environment: - POSTGRES_DB=${MATRIX_POSTGRES_DB:-synapse} - POSTGRES_USER=${MATRIX_POSTGRES_USER:-synapse} - POSTGRES_PASSWORD=${MATRIX_POSTGRES_PASSWORD:-change-this-matrix-db-password} - POSTGRES_INITDB_ARGS=--encoding=UTF8 --lc-collate=C --lc-ctype=C volumes: - ./matrix/postgres:/var/lib/postgresql/data networks: - traefik matrix-redis: image: redis:7-alpine restart: unless-stopped profiles: - matrix networks: - traefik matrix-synapse: image: ghcr.io/element-hq/synapse:latest restart: unless-stopped profiles: - matrix depends_on: - matrix-db - matrix-redis environment: - SYNAPSE_CONFIG_PATH=/data/homeserver.yaml volumes: - ./matrix/synapse:/data networks: - traefik labels: - "traefik.enable=true" - "traefik.docker.network=traefik" - "traefik.port=8008" - "traefik.http.services.fedeo-matrix.loadbalancer.server.port=8008" # Matrix Client-Server API - "traefik.http.routers.fedeo-matrix.rule=Host(`${MATRIX_HOMESERVER_HOST:-matrix.fedeo.de}`) && PathPrefix(`/_matrix`)" - "traefik.http.routers.fedeo-matrix.entrypoints=web" - "traefik.http.routers.fedeo-matrix.middlewares=fedeo-matrix-redirect-web-secure" - "traefik.http.routers.fedeo-matrix.service=fedeo-matrix" - "traefik.http.middlewares.fedeo-matrix-redirect-web-secure.redirectscheme.scheme=https" - "traefik.http.routers.fedeo-matrix-secure.rule=Host(`${MATRIX_HOMESERVER_HOST:-matrix.fedeo.de}`) && PathPrefix(`/_matrix`)" - "traefik.http.routers.fedeo-matrix-secure.entrypoints=web-secured" - "traefik.http.routers.fedeo-matrix-secure.tls.certresolver=mytlschallenge" - "traefik.http.routers.fedeo-matrix-secure.service=fedeo-matrix" # Matrix Federation API, nur öffnen wenn Federation gewünscht ist. - "traefik.http.routers.fedeo-matrix-federation.rule=Host(`${MATRIX_HOMESERVER_HOST:-matrix.fedeo.de}`) && PathPrefix(`/_matrix/federation`)" - "traefik.http.routers.fedeo-matrix-federation.entrypoints=web-secured" - "traefik.http.routers.fedeo-matrix-federation.tls.certresolver=mytlschallenge" - "traefik.http.routers.fedeo-matrix-federation.service=fedeo-matrix" matrix-well-known: image: nginx:1.27-alpine restart: unless-stopped profiles: - matrix volumes: - ./matrix/well-known:/usr/share/nginx/html/.well-known/matrix:ro networks: - traefik labels: - "traefik.enable=true" - "traefik.docker.network=traefik" - "traefik.port=80" - "traefik.http.services.fedeo-matrix-well-known.loadbalancer.server.port=80" - "traefik.http.middlewares.fedeo-matrix-well-known-cors.headers.accesscontrolalloworiginlist=*" - "traefik.http.middlewares.fedeo-matrix-well-known-cors.headers.accesscontrolallowmethods=GET,OPTIONS" - "traefik.http.middlewares.fedeo-matrix-well-known-cors.headers.accesscontrolallowheaders=Content-Type,Authorization" - "traefik.http.routers.fedeo-matrix-well-known.rule=Host(`${MATRIX_SERVER_NAME:-fedeo.de}`) && PathPrefix(`/.well-known/matrix`)" - "traefik.http.routers.fedeo-matrix-well-known.entrypoints=web-secured" - "traefik.http.routers.fedeo-matrix-well-known.tls.certresolver=mytlschallenge" - "traefik.http.routers.fedeo-matrix-well-known.middlewares=fedeo-matrix-well-known-cors" - "traefik.http.routers.fedeo-matrix-well-known.service=fedeo-matrix-well-known" matrix-turn: image: instrumentisto/coturn:4 restart: unless-stopped profiles: - matrix command: - --fingerprint - --use-auth-secret - --static-auth-secret=${MATRIX_TURN_SHARED_SECRET:-change-this-turn-secret} - --realm=${MATRIX_SERVER_NAME:-fedeo.de} - --listening-port=3478 - --tls-listening-port=5349 - --min-port=49160 - --max-port=49200 - --no-cli - --no-tlsv1 - --no-tlsv1_1 ports: - "3478:3478/tcp" - "3478:3478/udp" - "5349:5349/tcp" - "49160-49200:49160-49200/udp" networks: - traefik matrix-livekit: image: livekit/livekit-server:v1.9 restart: unless-stopped profiles: - matrix depends_on: - matrix-redis entrypoint: /bin/sh command: - -ec - | cat >/tmp/livekit.yaml </tmp/livekit.yaml <