No description
Find a file
Piotr Oleszczyk 2efdb2b785 fix(deploy): make LXC deploys atomic and fail-fast
Rebuild the deployment flow to prepare releases remotely, validate env/sudo prerequisites, run migrations in-release, and auto-rollback on health failures. Consolidate deployment docs and add a manual CI workflow so laptop and CI use the same push-based deploy path.
2026-03-07 01:14:30 +01:00
.agents/skills fix(api): rename 'metadata' to 'response_metadata' to avoid Pydantic conflict 2026-03-06 16:16:35 +01:00
.claude fix(api): rename 'metadata' to 'response_metadata' to avoid Pydantic conflict 2026-03-06 16:16:35 +01:00
.forgejo/workflows fix(deploy): make LXC deploys atomic and fail-fast 2026-03-07 01:14:30 +01:00
.playwright-mcp fix(api): rename 'metadata' to 'response_metadata' to avoid Pydantic conflict 2026-03-06 16:16:35 +01:00
backend fix(api): rename 'metadata' to 'response_metadata' to avoid Pydantic conflict 2026-03-06 16:16:35 +01:00
docs fix(deploy): make LXC deploys atomic and fail-fast 2026-03-07 01:14:30 +01:00
frontend feat(i18n): add Phase 3 observability translations (EN + PL) 2026-03-06 16:28:23 +01:00
nginx refactor(api): remove MCP server integration and docs references 2026-03-04 12:28:30 +01:00
scripts fix(deploy): make LXC deploys atomic and fail-fast 2026-03-07 01:14:30 +01:00
systemd feat(backend): move product pricing to async persisted jobs 2026-03-04 22:46:16 +01:00
.gitignore fix: load .env via python-dotenv; SQLite default for local dev 2026-02-26 20:51:13 +01:00
AGENTS.md docs(repo): define agent skills and frontend cookbook workflow 2026-03-05 10:49:07 +01:00
ai_call_log.json fix(api): rename 'metadata' to 'response_metadata' to avoid Pydantic conflict 2026-03-06 16:16:35 +01:00
deploy.sh fix(deploy): make LXC deploys atomic and fail-fast 2026-03-07 01:14:30 +01:00
opencode.json fix(api): rename 'metadata' to 'response_metadata' to avoid Pydantic conflict 2026-03-06 16:16:35 +01:00
PHASE1_COMPLETE.md feat(api): add LLM response validation and input sanitization 2026-03-06 10:16:47 +01:00
PHASE3_COMPLETE.md docs: add Phase 3 completion summary 2026-03-06 15:55:06 +01:00
README.md fix(deploy): make LXC deploys atomic and fail-fast 2026-03-07 01:14:30 +01:00
skills-lock.json fix(api): rename 'metadata' to 'response_metadata' to avoid Pydantic conflict 2026-03-06 16:16:35 +01:00

innercontext

Personal health and skincare data hub. Collects structured data (products, routines, lab results, medications, skin snapshots) and exposes it via a REST API and a web UI to an LLM agent.

Repository layout

backend/    Python backend — FastAPI REST API + SQLModel models
frontend/   SvelteKit web UI (Svelte 5, TypeScript, Tailwind CSS v4)
docs/       Deployment guides
nginx/      nginx config for production
systemd/    systemd service units

Backend quick start

Requirements: Python 3.12+, PostgreSQL, uv

cd backend

# Install dependencies
uv sync

# Set database URL (defaults to postgresql+psycopg://localhost/innercontext)
export DATABASE_URL=postgresql+psycopg://user:password@localhost/innercontext

# Start the API server (creates tables on first run)
uv run uvicorn main:app --reload

API docs available at http://localhost:8000/docs.

Frontend quick start

Requirements: Node.js 24 LTS+, pnpm

cd frontend

# Install dependencies
pnpm install

# Start dev server (proxies API calls to localhost:8000)
pnpm dev

UI available at http://localhost:5173.

API overview

Prefix Resource
/products Skincare / medication products + inventory
/inventory Individual inventory entries
/health/medications Medication entries and usage history
/health/lab-results Lab test results
/routines AM/PM skincare routines and steps
/routines/grooming-schedule Weekly grooming schedule
/skincare Weekly skin condition snapshots
/profile User profile (birth date, sex at birth)
/health-check Liveness probe

Frontend routes

Route Description
/ Dashboard
/products Product list
/products/new Add product
/products/[id] Product detail / edit
/routines Routine list
/routines/new Create routine
/routines/[id] Routine detail
/health/medications Medications
/health/lab-results Lab results
/skin Skin condition snapshots
/profile User profile

Development

cd backend

# Lint
uv run ruff check .

# Format
uv run black .
uv run isort .

# Tests
uv run pytest

Stack

  • Backend: Python 3.12, FastAPI, Uvicorn, SQLModel 0.0.37 + SQLAlchemy, Pydantic v2, PostgreSQL (psycopg3)
  • Frontend: SvelteKit 2, Svelte 5 (Runes), TypeScript, Tailwind CSS v4, shadcn-svelte

Deployment

Deployments are push-based from an external machine (laptop/CI runner) to the LXC host over SSH.