#!/bin/sh # Docker entrypoint for WiFi-DensePose sensing server. # # Supports two usage patterns: # # 1. No arguments — use defaults from environment: # docker run -e CSI_SOURCE=esp32 ruvnet/wifi-densepose:latest # # 2. Pass CLI flags directly: # docker run ruvnet/wifi-densepose:latest --source esp32 --tick-ms 500 # docker run ruvnet/wifi-densepose:latest --model /app/models/my.rvf # # Environment variables: # CSI_SOURCE — data source: auto (default), esp32, wifi, simulated # MODELS_DIR — directory to scan for .rvf model files (default: data/models) set -e # Route to cog-ha-matter (ADR-116) when invoked as: # docker run cog-ha-matter [--flags] # or via the short alias `ha-matter`. Strips the keyword and execs the # Home Assistant + Matter cog binary, defaulting --sensing-url to the # co-located sensing-server endpoint so docker-compose deployments work # out of the box. case "${1:-}" in cog-ha-matter|ha-matter) shift exec /app/cog-ha-matter \ --sensing-url "${SENSING_URL:-http://127.0.0.1:3000}" \ "$@" ;; homecore|homecore-server) # Route to the HOMECORE native Rust port of Home Assistant # (ADRs 126-134, v0.10.0). Default bind matches HA at :8123. shift exec /app/homecore-server \ --bind "${HOMECORE_BIND:-0.0.0.0:8123}" \ "$@" ;; esac # If the first argument looks like a flag (starts with -), prepend the # server binary so users can just pass flags: # docker run --source esp32 --tick-ms 500 if [ "${1#-}" != "$1" ] || [ -z "$1" ]; then set -- /app/sensing-server \ --source "${CSI_SOURCE:-auto}" \ --tick-ms 100 \ --ui-path /app/ui \ --http-port 3000 \ --ws-port 3001 \ --bind-addr 0.0.0.0 \ "$@" fi exec "$@"