// Single source of truth for runtime config is SREBOT/.env. Each spawned // process loads it independently (botscript.py via python-dotenv, server.js // and web/server.js via `require('dotenv').config()`, github_webhook_updater.py // via python-dotenv). Do NOT add `env:` blocks below or load dotenv here — // either would create a second config source that can silently shadow .env. const DEPLOY_PATH = __dirname; // Both bots share one venv at BOTS/SHARED/.venv (built from SHARED/requirements.txt). const PY_INTERPRETER = `${DEPLOY_PATH}/../SHARED/.venv/bin/python`; module.exports = { apps: [ // Discord Bot { name: 'srebot', script: 'start_bot.py', interpreter: PY_INTERPRETER, cwd: DEPLOY_PATH, instances: 1, autorestart: true, watch: false, max_memory_restart: '16000M', log_file: './logs/bot_combined.log', out_file: './logs/bot_out.log', error_file: './logs/bot_error.log', log_date_format: 'YYYY-MM-DD HH:mm:ss Z', merge_logs: true, kill_timeout: 5000, restart_delay: 3000 }, // API Server (reads SREBOT_API_PORT from .env) { name: 'srebot-api', script: 'server.js', interpreter: 'node', node_args: '--max-old-space-size=6144', cwd: DEPLOY_PATH, instances: 1, autorestart: true, watch: false, max_memory_restart: '4G', log_file: './logs/api_combined.log', out_file: './logs/api_out.log', error_file: './logs/api_error.log', log_date_format: 'YYYY-MM-DD HH:mm:ss Z', merge_logs: true, kill_timeout: 5000, restart_delay: 2000 }, // TSS read-only HTTP API (loopback). Proxied by relay-gateway as /api/tss/*. // Reads TSS_API_HOST/PORT from .env (default 127.0.0.1:6100). { name: 'tssbot-api', script: '-m', args: 'web.main', interpreter: PY_INTERPRETER, cwd: `${DEPLOY_PATH}/../TSSBOT`, instances: 1, autorestart: true, watch: false, max_memory_restart: '1G', log_file: `${DEPLOY_PATH}/logs/tssbot_api_combined.log`, out_file: `${DEPLOY_PATH}/logs/tssbot_api_out.log`, error_file: `${DEPLOY_PATH}/logs/tssbot_api_error.log`, log_date_format: 'YYYY-MM-DD HH:mm:ss Z', merge_logs: true, kill_timeout: 5000, restart_delay: 2000 }, // Unified relay gateway fronting SREBOT (sqb) and TSSBOT (tss): // - Proxies read-only API queries (/api/sqb/* -> SREBOT :6000; /api/tss/* -> TSS API or 501) // - Streams replay envelopes over /ws/sqb and /ws/tss // - Per-key auth (all/sqb/tss) via $STORAGE_VOL_PATH/relay_keys.json // Lives in BOTS/SHARED/relay_gateway; loads SREBOT/.env for shared config. // Reads SREBOT_EXTERNAL_HOST/PORT/UPSTREAM_URL + STORAGE_VOL_PATH from .env. { name: 'relay-gateway', script: '-m', args: 'relay_gateway.gateway', interpreter: PY_INTERPRETER, cwd: `${DEPLOY_PATH}/../SHARED`, instances: 1, autorestart: true, watch: false, max_memory_restart: '1G', log_file: `${DEPLOY_PATH}/logs/relay_gateway_combined.log`, out_file: `${DEPLOY_PATH}/logs/relay_gateway_out.log`, error_file: `${DEPLOY_PATH}/logs/relay_gateway_error.log`, log_date_format: 'YYYY-MM-DD HH:mm:ss Z', merge_logs: true, kill_timeout: 5000, restart_delay: 2000 }, // GitHub Webhook Receiver (auto-deploy on push to main). // Reads SREBOT_WEBHOOK_PORT from .env. { name: 'srebot-webhook', script: 'github_webhook_updater.py', interpreter: PY_INTERPRETER, cwd: DEPLOY_PATH, instances: 1, autorestart: true, watch: false, max_memory_restart: '500M', log_file: './logs/webhook_combined.log', out_file: './logs/webhook_out.log', error_file: './logs/webhook_error.log', log_date_format: 'YYYY-MM-DD HH:mm:ss Z', merge_logs: true, kill_timeout: 3000, restart_delay: 2000 }, // Website (reads SREBOT_WEB_PORT from .env) { name: 'srebot-web', script: 'server.js', cwd: `${DEPLOY_PATH}/web`, instances: 3, exec_mode: 'cluster', autorestart: true, watch: false, max_memory_restart: '500M', log_file: './logs/web_combined.log', out_file: './logs/web_out.log', error_file: './logs/web_error.log', log_date_format: 'YYYY-MM-DD HH:mm:ss Z', merge_logs: true, kill_timeout: 5000 } ] };