version: '3.7' x-common-variables: &common-variables HOST: ${HOST} HTTP_PROTOCOL: ${HTTP_PROTOCOL} OTEL_COLLECTOR_HOST: ${OTEL_COLLECTOR_HOST} NODE_ENV: ${ENVIRONMENT} BILLING_ENABLED: ${BILLING_ENABLED} BILLING_PUBLIC_KEY: ${BILLING_PUBLIC_KEY} SUBSCRIPTION_PLAN_BASIC: ${SUBSCRIPTION_PLAN_BASIC} SUBSCRIPTION_PLAN_GROWTH: ${SUBSCRIPTION_PLAN_GROWTH} SUBSCRIPTION_PLAN_SCALE: ${SUBSCRIPTION_PLAN_SCALE} SUBSCRIPTION_PLAN_ENTERPRISE: ${SUBSCRIPTION_PLAN_ENTERPRISE} ANALYTICS_KEY: ${ANALYTICS_KEY} ANALYTICS_HOST: ${ANALYTICS_HOST} SERVER_ACCOUNTS_HOSTNAME: accounts SERVER_REALTIME_HOSTNAME: realtime SERVER_APP_HOSTNAME: app SERVER_WORKFLOW_HOSTNAME: workflow SERVER_ALERT_HOSTNAME: alert SERVER_INGESTOR_HOSTNAME: ingestor SERVER_TEST_SERVER_HOSTNAME: test-server SERVER_WORKERS_HOSTNAME: workers SERVER_STATUS_PAGE_HOSTNAME: status-page SERVER_DASHBOARD_HOSTNAME: dashboard SERVER_ADMIN_DASHBOARD_HOSTNAME: admin-dashboard SERVER_OTEL_COLLECTOR_HOSTNAME: otel-collector #Ports. Usually they don't need to change. APP_PORT: ${APP_PORT} WORKFLOW_PORT: ${WORKFLOW_PORT} ALERT_PORT: ${ALERT_PORT} INGESTOR_PORT: ${INGESTOR_PORT} PROBE_PORT: ${PROBE_PORT} TEST_SERVER_PORT: ${TEST_SERVER_PORT} REALTIME_PORT: ${REALTIME_PORT} WORKERS_PORT: ${WORKERS_PORT} ACCOUNTS_PORT: ${ACCOUNTS_PORT} STATUS_PAGE_PORT: ${STATUS_PAGE_PORT} DASHBOARD_PORT: ${DASHBOARD_PORT} ADMIN_DASHBOARD_PORT: ${ADMIN_DASHBOARD_PORT} OTEL_COLLECTOR_PORT: ${OTEL_COLLECTOR_PORT} x-common-ui-variables: &common-ui-variables <<: *common-variables IS_SERVER: "false" STATUS_PAGE_CNAME_RECORD: ${STATUS_PAGE_CNAME_RECORD} x-common-server-variables: &common-server-variables <<: *common-variables ONEUPTIME_SECRET: ${ONEUPTIME_SECRET} DATABASE_PORT: ${DATABASE_PORT} DATABASE_USERNAME: ${DATABASE_USERNAME} DATABASE_PASSWORD: ${DATABASE_PASSWORD} DATABASE_NAME: ${DATABASE_NAME} DATABASE_HOST: ${DATABASE_HOST} DATABASE_SSL_CA: ${DATABASE_SSL_CA} DATABASE_SSL_KEY: ${DATABASE_SSL_KEY} DATABASE_SSL_CERT: ${DATABASE_SSL_CERT} DATABASE_SSL_REJECT_UNAUTHORIZED: ${DATABASE_SSL_REJECT_UNAUTHORIZED} REDIS_USERNAME: ${REDIS_USERNAME} REDIS_PASSWORD: ${REDIS_PASSWORD} REDIS_HOST: ${REDIS_HOST} REDIS_PORT: ${REDIS_PORT} REDIS_DB: ${REDIS_DB} REDIS_TLS_CA: ${REDIS_TLS_CA} REDIS_TLS_SENTINEL_MODE: ${REDIS_TLS_SENTINEL_MODE} ENCRYPTION_SECRET: ${ENCRYPTION_SECRET} BILLING_PRIVATE_KEY: ${BILLING_PRIVATE_KEY} BILLING_PUBLIC_KEY: ${BILLING_PUBLIC_KEY} BILLING_ENABLED: ${BILLING_ENABLED} CLICKHOUSE_USER: ${CLICKHOUSE_USER} CLICKHOUSE_PASSWORD: ${CLICKHOUSE_PASSWORD} CLICKHOUSE_DATABASE: ${CLICKHOUSE_DATABASE} CLICKHOUSE_HOST: ${CLICKHOUSE_HOST} CLICKHOUSE_PORT: ${CLICKHOUSE_PORT} IS_SERVER: "true" DISABLE_AUTOMATIC_INCIDENT_CREATION: ${DISABLE_AUTOMATIC_INCIDENT_CREATION} services: haraka: networks: - oneuptime image: oneuptime/haraka:${APP_TAG} restart: always environment: SMTP_USERNAME: oneuptime SMTP_PASSWORD: ${INTERNAL_SMTP_PASSWORD} DKIM_SELECTOR: oneuptime DOMAIN: ${INTERNAL_SMTP_SENDING_DOMAIN} DKIM_PRIVATE_KEY: ${INTERNAL_SMTP_DKIM_PRIVATE_KEY_AS_BASE64} DKIM_PUBLIC_KEY: ${INTERNAL_SMTP_DKIM_PUBLIC_KEY_AS_BASE64} redis: image: redis:7.0.12 restart: always networks: - oneuptime command: redis-server --requirepass "${REDIS_PASSWORD}" --save "" --appendonly no environment: REDIS_PASSWORD: ${REDIS_PASSWORD} clickhouse: image: clickhouse/clickhouse-server:23.7 restart: always environment: CLICKHOUSE_USER: ${CLICKHOUSE_USER} CLICKHOUSE_PASSWORD: ${CLICKHOUSE_PASSWORD} CLICKHOUSE_DB: ${CLICKHOUSE_DATABASE} CLICKHOUSE_DEFAULT_ACCESS_MANAGEMENT: 1 networks: - oneuptime volumes: - clickhouse:/var/lib/clickhouse/ postgres: image: postgres:15 restart: always environment: POSTGRES_USER: ${DATABASE_USERNAME} POSTGRES_PASSWORD: ${DATABASE_PASSWORD} POSTGRES_DB: ${DATABASE_NAME} networks: - oneuptime volumes: - postgres:/var/lib/postgresql/data accounts: networks: - oneuptime restart: always environment: <<: *common-ui-variables PORT: ${ACCOUNTS_PORT} admin-dashboard: networks: - oneuptime restart: always environment: <<: *common-ui-variables PORT: ${ADMIN_DASHBOARD_PORT} dashboard: networks: - oneuptime restart: always environment: <<: *common-ui-variables PORT: ${DASHBOARD_PORT} status-page: networks: - oneuptime restart: always environment: <<: *common-ui-variables PORT: ${STATUS_PAGE_PORT} depends_on: - accounts - app test-server: networks: - oneuptime restart: always environment: <<: *common-server-variables PORT: ${TEST_SERVER_PORT} app: networks: - oneuptime restart: always environment: <<: *common-server-variables PORT: ${APP_PORT} SMS_DEFAULT_COST_IN_CENTS: ${SMS_DEFAULT_COST_IN_CENTS} CALL_DEFAULT_COST_IN_CENTS_PER_MINUTE: ${CALL_DEFAULT_COST_IN_CENTS_PER_MINUTE} SMS_HIGH_RISK_COST_IN_CENTS: ${SMS_HIGH_RISK_COST_IN_CENTS} CALL_HIGH_RISK_COST_IN_CENTS_PER_MINUTE: ${CALL_HIGH_RISK_COST_IN_CENTS_PER_MINUTE} INTERNAL_SMTP_EMAIL: ${INTERNAL_SMTP_EMAIL} INTERNAL_SMTP_FROM_NAME: ${INTERNAL_SMTP_FROM_NAME} INTERNAL_SMTP_PASSWORD: ${INTERNAL_SMTP_PASSWORD} depends_on: - redis - postgres links: - redis - postgres workflow: networks: - oneuptime restart: always environment: <<: *common-server-variables PORT: ${WORKFLOW_PORT} depends_on: - redis - postgres links: - redis - postgres workers: networks: - oneuptime restart: always environment: <<: *common-server-variables PORT: ${WORKERS_PORT} ENVIRONMENT: ${ENVIRONMENT} depends_on: - postgres links: - postgres volumes: - ./Certs:/usr/src/Certs probe-1: networks: - oneuptime restart: always environment: <<: *common-server-variables PORT: ${PROBE_PORT} PROBE_NAME: ${GLOBAL_PROBE_1_NAME} PROBE_DESCRIPTION: ${GLOBAL_PROBE_1_DESCRIPTION} PROBE_MONITORING_WORKERS: ${GLOBAL_PROBE_1_MONITORING_WORKERS} PROBE_KEY: ${GLOBAL_PROBE_1_KEY} INGESTOR_URL: http://${INGESTOR_HOSTNAME} PROBE_MONITOR_FETCH_LIMIT: ${GLOBAL_PROBE_1_MONITOR_FETCH_LIMIT} depends_on: - ingestor links: - ingestor probe-2: networks: - oneuptime restart: always environment: <<: *common-server-variables PORT: ${PROBE_PORT} PROBE_NAME: ${GLOBAL_PROBE_2_NAME} PROBE_DESCRIPTION: ${GLOBAL_PROBE_2_DESCRIPTION} PROBE_MONITORING_WORKERS: ${GLOBAL_PROBE_2_MONITORING_WORKERS} PROBE_KEY: ${GLOBAL_PROBE_2_KEY} INGESTOR_URL: http://${INGESTOR_HOSTNAME} PROBE_MONITOR_FETCH_LIMIT: ${GLOBAL_PROBE_2_MONITOR_FETCH_LIMIT} depends_on: - ingestor links: - ingestor otel-collector: networks: - oneuptime restart: always ports: - '4317:4317' - '4318:4318' ingestor: networks: - oneuptime restart: always environment: <<: *common-server-variables PORT: ${INGESTOR_PORT} depends_on: - redis - postgres links: - redis - postgres ingress: depends_on: - accounts - app - dashboard - otel-collector restart: always networks: - oneuptime environment: <<: *common-variables ports: - '${ONEUPTIME_HTTP_PORT}:80' - '${ONEUPTIME_HTTPS_PORT}:443' volumes: - ./Certs:/etc/nginx/certs volumes: postgres: clickhouse: networks: oneuptime: driver: bridge