rubis/docs/tech/dev-setup.md
ordinarthur a8c7ab539a chore(dev): swap mailhog → mailpit (multi-arch, maintenu)
mailhog n'est plus maintenu et ne ship qu'en amd64 — sur Apple Silicon ça déclenche un warning Rosetta. Mailpit est le successeur drop-in (mêmes ports SMTP 1025 / UI 8025), multi-arch, activement maintenu.
2026-05-06 13:02:36 +02:00

101 lines
3.3 KiB
Markdown

# Dev setup — environnement local
> Version : 0.1 · 2026-05-06
Tout ce qu'il faut pour faire tourner Rubis en local : services backing (Postgres, Redis, MinIO, Mailhog) + l'API + le SPA.
## Prérequis
- **Node 22+** (cf. `engines` dans `package.json`)
- **pnpm 10+**
- **Docker + Docker Compose v2** (pour les services backing)
## 1. Services backing — docker-compose.dev.yml
Un seul fichier à la racine fait tourner les 4 services dont l'API a besoin :
| Service | Port hôte | Port interne | Notes |
|---|---|---|---|
| **Postgres** | 5433 | 5432 | DB applicative `rubis_dev` (user `rubis` / pass `rubis`) |
| **Redis** | 6380 | 6379 | Backend BullMQ + cache |
| **MinIO API** | 9100 | 9000 | S3-compatible. Bucket `rubis-invoices` créé au boot. |
| **MinIO Console** | 9101 | 9001 | UI web : http://localhost:9101 — login `rubis` / `rubis-dev-secret` |
| **Mailpit SMTP** | 1025 | 1025 | Catch-all pour les emails locaux |
| **Mailpit UI** | 8025 | 8025 | UI web : http://localhost:8025 |
Les ports hôte sont **décalés** (5433, 6380, 9100…) pour éviter les collisions avec un Postgres/Redis perso éventuellement déjà lancé.
### Commandes raccourcies
```bash
pnpm dev:up # Démarrage en background
pnpm dev:logs # Suivre les logs
pnpm dev:down # Arrêt (volumes conservés)
pnpm dev:reset # Arrêt + suppression des volumes (reset DB / MinIO complet)
```
### Vérifier que ça tourne
```bash
docker compose -f docker-compose.dev.yml ps
```
Tous les services doivent être `healthy` (sauf `minio-bootstrap` qui sort après avoir créé le bucket — c'est normal).
## 2. API (apps/api)
```bash
cd apps/api
cp .env.example .env # Si pas déjà fait
pnpm dev:api # Depuis la racine, ou : pnpm -F api dev
```
**Première fois** :
```bash
pnpm -F api exec node ace migration:run
pnpm -F api exec node ace db:seed
```
L'API écoute sur http://localhost:3333.
### Bascule SQLite (mode dégradé)
Si Docker n'est pas dispo, on peut basculer sur SQLite :
```bash
# Dans apps/api/.env
DB_CONNECTION=sqlite
```
Les migrations tournent sur les deux. Pour les jobs/storage/mail, il faut quand même Redis/MinIO/Mailhog — donc Docker reste recommandé.
## 3. Web (apps/web)
```bash
pnpm dev:web
# → http://localhost:5173
```
Tant que `VITE_USE_MOCKS=true` dans `apps/web/.env`, le SPA tape MSW et n'a pas besoin de l'API. Quand le backend est prêt à servir un domaine, on bascule la valeur sur `false`.
## 4. Trousseau de variables d'env
Voir `apps/api/.env.example` — c'est la source de vérité. Récap :
- **PG_*** : connexion Postgres (default ports décalés docker-compose)
- **REDIS_*** : BullMQ
- **S3_*** : MinIO (driver S3 d'@adonisjs/drive)
- **MAIL_*** + **SMTP_*** : Mailhog en dev, Resend en prod (`MAIL_DRIVER=resend` + `RESEND_API_KEY`)
- **OCR_PROVIDER** : `mock` en dev, `mistral` quand l'API key est en place
- **ACCESS_TOKEN_TTL_MINUTES** / **REFRESH_TOKEN_TTL_DAYS** : durées d'auth
## 5. Données de seed
`pnpm -F api exec node ace db:seed` lance :
- `default_plans_seeder` — 4 plans pré-fournis (Standard B2B, Rapide, Patient, Ferme)
- `demo_data_seeder` — compte `demo@rubis.fr` + clients + factures (dev uniquement)
Les seeders réutilisent les fixtures de `apps/web/src/mocks/seed.ts` pour garantir la cohérence MSW ↔ vraie API.