generated from coulomb/repo-seed
Locked in cytoscape.js as visualization for dep graph
This commit is contained in:
18
.dockerignore
Normal file
18
.dockerignore
Normal file
@@ -0,0 +1,18 @@
|
||||
.venv
|
||||
.pytest_cache
|
||||
__pycache__
|
||||
**/__pycache__
|
||||
*.pyc
|
||||
*.pyo
|
||||
*.pyd
|
||||
.env
|
||||
.env.*
|
||||
!.env.example
|
||||
dashboard/node_modules
|
||||
dashboard/dist
|
||||
dashboard/src/.observablehq/cache
|
||||
dashboard/.observablehq/cache
|
||||
kubectl
|
||||
tests
|
||||
docs
|
||||
infra
|
||||
49
Dockerfile
Normal file
49
Dockerfile
Normal file
@@ -0,0 +1,49 @@
|
||||
FROM python:3.12-slim AS runtime
|
||||
|
||||
ENV PYTHONDONTWRITEBYTECODE=1 \
|
||||
PYTHONUNBUFFERED=1 \
|
||||
PATH="/app/.venv/bin:${PATH}"
|
||||
|
||||
WORKDIR /app
|
||||
|
||||
RUN apt-get update \
|
||||
&& apt-get install -y --no-install-recommends curl ca-certificates \
|
||||
&& rm -rf /var/lib/apt/lists/* \
|
||||
&& pip install --no-cache-dir uv
|
||||
|
||||
COPY pyproject.toml ./
|
||||
|
||||
RUN python - <<'PY' > /tmp/requirements.txt
|
||||
import tomllib
|
||||
|
||||
with open("pyproject.toml", "rb") as f:
|
||||
project = tomllib.load(f)["project"]
|
||||
|
||||
for dep in project["dependencies"]:
|
||||
# llm-connect is currently a local editable test integration in this repo.
|
||||
# The State Hub API/MCP runtime does not import it, and a container build
|
||||
# must not depend on /home/worsch existing inside the image.
|
||||
if dep == "llm-connect":
|
||||
continue
|
||||
print(dep)
|
||||
PY
|
||||
|
||||
RUN uv venv /app/.venv \
|
||||
&& uv pip install --python /app/.venv/bin/python --no-cache -r /tmp/requirements.txt
|
||||
|
||||
COPY alembic.ini ./
|
||||
COPY api/ ./api/
|
||||
COPY flows/ ./flows/
|
||||
COPY mcp_server/ ./mcp_server/
|
||||
COPY migrations/ ./migrations/
|
||||
COPY policies/ ./policies/
|
||||
COPY prompts/ ./prompts/
|
||||
COPY scripts/ ./scripts/
|
||||
COPY task_flow_engine/ ./task_flow_engine/
|
||||
|
||||
EXPOSE 8000
|
||||
|
||||
HEALTHCHECK --interval=30s --timeout=5s --start-period=20s --retries=3 \
|
||||
CMD python -c "import urllib.request; urllib.request.urlopen('http://127.0.0.1:8000/state/health', timeout=3).read()"
|
||||
|
||||
CMD ["uvicorn", "api.main:app", "--host", "0.0.0.0", "--port", "8000"]
|
||||
56
docs/container-image.md
Normal file
56
docs/container-image.md
Normal file
@@ -0,0 +1,56 @@
|
||||
# State Hub Container Image
|
||||
|
||||
The State Hub production image is built from `state-hub/Dockerfile`.
|
||||
|
||||
## Build
|
||||
|
||||
```bash
|
||||
cd state-hub
|
||||
docker build -t state-hub:local .
|
||||
```
|
||||
|
||||
The image installs runtime dependencies from `pyproject.toml` and excludes the
|
||||
local editable `llm-connect` dependency. `llm-connect` is currently used by the
|
||||
test suite only; the API and MCP runtime do not import it. Removing that
|
||||
workstation-local path from the image keeps cluster builds reproducible.
|
||||
|
||||
## Runtime
|
||||
|
||||
Required environment:
|
||||
|
||||
```bash
|
||||
DATABASE_URL=postgresql+asyncpg://USER:PASSWORD@HOST:5432/DB
|
||||
API_BASE=http://127.0.0.1:8000
|
||||
```
|
||||
|
||||
The container starts:
|
||||
|
||||
```bash
|
||||
uvicorn api.main:app --host 0.0.0.0 --port 8000
|
||||
```
|
||||
|
||||
It includes Alembic migrations and can run migrations with:
|
||||
|
||||
```bash
|
||||
docker run --rm --env DATABASE_URL=... state-hub:local alembic upgrade head
|
||||
```
|
||||
|
||||
## Verification
|
||||
|
||||
After start, check:
|
||||
|
||||
```bash
|
||||
curl http://127.0.0.1:8000/state/health
|
||||
```
|
||||
|
||||
Expected response:
|
||||
|
||||
```json
|
||||
{"status":"ok","db":"connected"}
|
||||
```
|
||||
|
||||
## Registry
|
||||
|
||||
The final registry target is intentionally not hardcoded yet. CUST-WP-0011
|
||||
still has an open human decision for Gitea registry versus an interim external
|
||||
registry.
|
||||
Reference in New Issue
Block a user