cloud-dev-environment
Installation
SKILL.md
Cloud Development Environment
Services overview
- Main app (
apps/web): Next.js 16 app (Turbopack). Runs on port 3000. - PostgreSQL 16: Primary database. Runs on port 5432 via
docker-compose.dev.yml. - Redis 7 + serverless-redis-http: Caching/rate-limiting. Redis on port 6380, HTTP proxy on port 8079.
Starting services
- Start Docker daemon if needed:
sudo dockerd &>/dev/null &, then confirm withdocker info(orsudo docker infoif the client cannot reach the daemon yet). - Start databases from repo root:
docker compose -f docker-compose.dev.yml up -d. If you get permission denied on/var/run/docker.sock, run the same command withsudo docker composeinstead of making the socket world-writable. - Run Prisma migrations:
cd apps/web && pnpm prisma:migrate:local(usesdotenv -e .env.local; do NOT use bareprisma migrate dev— it won't load.env.local). - Start dev server:
pnpm devfrom repo root.
Environment file
The app reads apps/web/.env.local. Required non-obvious env vars beyond .env.example defaults:
DEFAULT_LLM_PROVIDER(e.g.openai) — app crashes at startup without this.GOOGLE_CLIENT_IDandGOOGLE_CLIENT_SECRET— hard-required byenv.tsvalidation. Use Google emulator credentials for local dev (see below).UPSTASH_REDIS_TOKENmust be set todev_tokento match theSRH_TOKENdefault indocker-compose.dev.yml.MICROSOFT_WEBHOOK_CLIENT_STATE— required ifMICROSOFT_CLIENT_IDis set.