- Drop @supabase/supabase-js entirely; add drizzle-orm + postgres (porsager) driver - New packages/db: schema (pgSchema ordinarthur_os), client factory, migrate runner, drizzle-kit config - SQL migrations: 0000_init (pgcrypto + schema), 0001_jobs (jobs + job_search_criteria, no RLS) - Rewrite apps/api db module with DI symbols DB/DB_HANDLE + @InjectDb() decorator - Rewrite jobs.service.ts with Drizzle queries (upsert via onConflictDoUpdate, arrayOverlaps for stack filter) - Replace SUPABASE_* env vars with DATABASE_URL in env config + .env.example - Add docker-compose.yml (Postgres 16-alpine, dev only) - Add deploy/k8s/postgres.yaml (StatefulSet + PVC), migrate.job.yaml, updated secrets.template.yaml - Update all docs (README, PLAN, ARCHITECTURE, CLAUDE.md, AGENTS.md, packages/db/README.md) Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
36 lines
1.1 KiB
YAML
36 lines
1.1 KiB
YAML
# Compose dev-only pour ordinarthur-os.
|
|
# Pas destiné à la prod (la prod tourne sur k3s via deploy/k8s/postgres.yaml).
|
|
#
|
|
# Usage :
|
|
# docker compose up -d # lance Postgres sur :5432
|
|
# pnpm --filter @ordinarthur-os/db migrate # applique les migrations
|
|
# docker compose logs -f postgres # suivre les logs
|
|
# docker compose down # stop (garde le volume)
|
|
# docker compose down -v # stop + wipe data
|
|
#
|
|
# Les credentials matchent `apps/api/.env.example` pour que `DATABASE_URL`
|
|
# fonctionne sans config supplémentaire.
|
|
|
|
services:
|
|
postgres:
|
|
image: postgres:16-alpine
|
|
container_name: ordinarthur-os-postgres
|
|
restart: unless-stopped
|
|
ports:
|
|
- "5432:5432"
|
|
environment:
|
|
POSTGRES_USER: ordinarthur
|
|
POSTGRES_PASSWORD: changeme
|
|
POSTGRES_DB: ordinarthur_os
|
|
volumes:
|
|
- postgres-data:/var/lib/postgresql/data
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U ordinarthur -d ordinarthur_os"]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 10
|
|
|
|
volumes:
|
|
postgres-data:
|
|
name: ordinarthur-os-postgres-data
|