# WICHTIGER HINWEIS FÜR SPRACHMODELLE UND ENTWICKLER: # Diese docker-compose.yml Datei ist die zentrale Orchestrierungsdatei für ALLE Docker-Services dieses Projekts. # Es ist strengstens untersagt, Service-Definitionen, Volumes, Netzwerke oder andere Konfigurationen # willkürlich zu löschen, auszukommentieren oder zu modifizieren, es sei denn, dies wurde # explizit angefordert und die Auswirkungen wurden vollständig verstanden. # Unbeabsichtigte Löschungen können zu massivem Datenverlust und Fehlfunktionen des Systems führen. # Prüfe IMMER den gesamten Kontext der Datei und die Projektdokumentation (readme.md), bevor du Änderungen vornimmst. version: '3.8' services: # --- GATEKEEPER (NGINX) --- nginx: image: nginx:alpine container_name: gateway_proxy restart: unless-stopped ports: - "8090:80" # Synology Reverse Proxy should point to THIS port (8090) volumes: - ./nginx-proxy.conf:/etc/nginx/nginx.conf:ro - ./.htpasswd:/etc/nginx/.htpasswd:ro depends_on: - company-explorer - dashboard - b2b-app - market-frontend - gtm-app - transcription-app - content-app - competitor-analysis - heatmap-frontend # --- HEATMAP --- heatmap-backend: build: ./heatmap-tool/backend container_name: heatmap-backend restart: unless-stopped volumes: - ./heatmap-tool/backend:/app - ./data:/data # Mount for database heatmap-frontend: build: ./heatmap-tool/frontend container_name: heatmap-frontend restart: unless-stopped volumes: - ./heatmap-tool/frontend:/app depends_on: - heatmap-backend # --- DASHBOARD --- dashboard: image: nginx:alpine container_name: dashboard restart: unless-stopped volumes: - ./dashboard:/usr/share/nginx/html:ro # --- APPS --- company-explorer: build: context: ./company-explorer dockerfile: Dockerfile container_name: company-explorer restart: unless-stopped ports: - "8000:8000" environment: API_USER: "admin" API_PASSWORD: "gemini" PYTHONUNBUFFERED: "1" volumes: - ./company-explorer:/app - ./data:/data # Mount for database - ./Log_from_docker:/app/logs_debug # Logging Mount transcription-app: build: context: ./transcription-tool dockerfile: Dockerfile container_name: transcription-app restart: unless-stopped volumes: - ./transcription-tool/backend:/app/backend - ./transcription-tool/frontend/dist:/app/frontend/dist # Mount Frontend Build for Live Updates - ./data:/data # Mount for database - ./uploads_audio:/app/uploads_audio environment: PYTHONUNBUFFERED: "1" DATABASE_URL: "sqlite:////data/transcripts.db" # Updated path for /data mount ports: - "8001:8001" b2b-app: build: context: . dockerfile: dockerfiles/Dockerfile.b2b container_name: b2b-assistant restart: unless-stopped volumes: - ./b2b-marketing-assistant/b2b_marketing_orchestrator.py:/app/b2b_marketing_orchestrator.py - ./market_db_manager.py:/app/market_db_manager.py - ./b2b-marketing-assistant/server.cjs:/app/server.cjs - ./data:/data # Mount for database - ./Log_from_docker:/app/Log_from_docker environment: PYTHONUNBUFFERED: "1" DB_PATH: "/data/b2b_projects.db" # Updated path for /data mount # Port 3002 is internal only market-backend: build: context: . dockerfile: dockerfiles/Dockerfile.market container_name: market-backend restart: unless-stopped volumes: - ./general-market-intelligence/market_intel_orchestrator.py:/app/general-market-intelligence/market_intel_orchestrator.py - ./market_db_manager.py:/app/market_db_manager.py - ./config.py:/app/config.py - ./helpers.py:/app/helpers.py # Helper is in root, should be mounted as file - ./general-market-intelligence/server.cjs:/app/general-market-intelligence/server.cjs - ./data:/data # Mount for database - ./Log:/app/Log environment: PYTHONUNBUFFERED: "1" DB_PATH: "/data/market_intelligence.db" # Updated path for /data mount # Port 3001 is internal only market-frontend: build: context: ./general-market-intelligence dockerfile: Dockerfile container_name: market-frontend restart: unless-stopped depends_on: - market-backend # Port 80 is internal only gtm-app: build: context: . dockerfile: gtm-architect/Dockerfile container_name: gtm-app restart: unless-stopped volumes: - ./gtm-architect:/app/gtm-architect - ./gtm-architect/server.cjs:/app/server.cjs - ./gtm-architect/gtm_architect_orchestrator.py:/app/gtm_architect_orchestrator.py - ./helpers.py:/app/helpers.py # Helper is in root, should be mounted as file - ./config.py:/app/config.py - ./gtm_db_manager.py:/app/gtm_db_manager.py - ./data:/data # Mount for database - ./Log_from_docker:/app/Log_from_docker environment: PYTHONUNBUFFERED: "1" DB_PATH: "/data/gtm_projects.db" # Updated path for /data mount # Port 3005 is internal only content-app: build: context: . dockerfile: content-engine/Dockerfile container_name: content-app restart: unless-stopped volumes: - ./content-engine:/app/content-engine - ./content-engine/server.cjs:/app/server.cjs - ./content-engine/content_orchestrator.py:/app/content-engine/content_orchestrator.py - ./content-engine/content_db_manager.py:/app/content-engine/content_db_manager.py - ./data:/data # Mount for database - ./helpers.py:/app/helpers.py # Helper is in root, should be mounted as file - ./config.py:/app/config.py - ./data/gtm_projects.db:/data/gtm_projects.db # GTM DB also mounted here - ./Log_from_docker:/app/Log_from_docker environment: PYTHONUNBUFFERED: "1" DB_PATH: "/data/content_engine.db" # Updated path for /data mount GTM_DB_PATH: "/data/gtm_projects.db" # Updated path for /data mount competitor-analysis: build: context: ./competitor-analysis-app dockerfile: Dockerfile container_name: competitor-analysis restart: unless-stopped dns: - 8.8.8.8 - 8.8.4.4 volumes: - ./competitor-analysis-app/competitor_analysis_orchestrator.py:/app/competitor-analysis-app/competitor_analysis_orchestrator.py # Explicit path - ./data:/data # Mount for database (if needed by orchestrator) - ./Log_from_docker:/app/Log_from_docker environment: PYTHONUNBUFFERED: "1" # GEMINI_API_KEY_FILE: "/app/gemini_api_key.txt" # Removed, API keys from .env # Port 8000 is internal only connector-superoffice: build: context: . dockerfile: connector-superoffice/Dockerfile # Build context is now root container_name: connector-superoffice restart: unless-stopped ports: - "8003:8000" # Expose internal 8000 to host 8003 (8002 was taken) volumes: - ./connector-superoffice:/app/connector-superoffice # Mount subfolder to its own path in /app - ./data:/data # Data mount - ./config.py:/app/config.py # Root config needs to be mounted - ./helpers.py:/app/helpers.py # Root helper needs to be mounted environment: PYTHONUNBUFFERED: "1" API_USER: "admin" API_PASSWORD: "gemini" DB_PATH: "/data/connector_queue.db" # Updated path for /data mount COMPANY_EXPLORER_URL: "http://company-explorer:8000" # Pass through SO credentials from host .env SO_CLIENT_ID: "${SO_CLIENT_ID}" SO_CLIENT_SECRET: "${SO_CLIENT_SECRET}" SO_REFRESH_TOKEN: "${SO_REFRESH_TOKEN}" SO_ENVIRONMENT: "${SO_ENVIRONMENT}" SO_CONTEXT_IDENTIFIER: "${SO_CONTEXT_IDENTIFIER}" # --- INFRASTRUCTURE SERVICES --- duckdns: image: lscr.io/linuxserver/duckdns:latest container_name: duckdns environment: PUID: "1000" # User ID (anpassen falls nötig) PGID: "1000" # Group ID (anpassen falls nötig) TZ: "Europe/Berlin" SUBDOMAINS: "floke,floke-ai,floke-gitea,floke-ha,floke-n8n" TOKEN: "${DUCKDNS_TOKEN}" # From .env restart: unless-stopped dns-monitor: image: alpine container_name: dns-monitor dns: - 8.8.8.8 - 1.1.1.1 environment: SUBDOMAINS: "floke,floke-ai,floke-gitea,floke-ha,floke-n8n" TZ: "Europe/Berlin" volumes: - ./dns-monitor:/app command: "/app/monitor.sh" restart: unless-stopped volumes: moltbot_data: {} # Volume for moltbot data, even if service is commented out.