Patterns backend/fullstack : API REST, architecture 3 couches, auth, base de données, error handling, middleware, real-time, file upload. Se charge quand le code touche des routes, controllers, services, DB, auth ou API.
From codebloomnpx claudepluginhub vendeesign/codebloom --plugin codebloomThis skill uses the workspace's default tool permissions.
Searches, retrieves, and installs Agent Skills from prompts.chat registry using MCP tools like search_skills and get_skill. Activates for finding skills, browsing catalogs, or extending Claude.
Searches prompts.chat for AI prompt templates by keyword or category, retrieves by ID with variable handling, and improves prompts via AI. Use for discovering or enhancing prompts.
Compares coding agents like Claude Code and Aider on custom YAML-defined codebase tasks using git worktrees, measuring pass rate, cost, time, and consistency.
Patterns éprouvés pour tout projet backend ou fullstack. Se charge automatiquement quand du code touche des routes, controllers, services, base de données, auth ou API.
Controller (HTTP) → Service (Business) → Repository (Data Access)
| Couche | Fait | Jamais |
|---|---|---|
| Controller | Parse request, valide input, appelle service, formate réponse | Business logic, requêtes DB |
| Service | Règles métier, orchestration, transactions | Types HTTP, accès DB direct |
| Repository | Requêtes DB, appels API externes | Business logic, types HTTP |
Organiser par feature, pas par couche technique.
orders/contient controller + service + repository + tests, pascontrollers/,services/,repositories/.
RequestID → Logging → CORS → RateLimit → BodyParse → Auth → Authz
→ Validation → Handler → ErrorHandler → Response
/order-items, pas /getOrderItemsfirstNameX-Request-Id/orders/123/items. Au-delà : query params → GET /reviews?orderId=123| Code | Quand |
|---|---|
| 200 | GET/PATCH/PUT success |
| 201 | POST avec Location header |
| 204 | DELETE sans contenu |
| 400 | Parse failure |
| 401 | Auth manquant |
| 403 | Permission refusée |
| 404 | Ressource introuvable |
| 409 | Conflit (doublon) |
| 422 | Validation échouée |
| 429 | Rate limit |
{
"type": "https://api.example.com/errors/insufficient-funds",
"title": "Insufficient Funds",
"status": 422,
"detail": "Account balance $10.00 < withdrawal $50.00",
"request_id": "req_7f3a8b2c"
}
Toutes les erreurs suivent ce format. Request ID toujours inclus.
Cursor (préféré pour gros datasets) : retourne next_cursor + has_more
Offset : pour datasets stables et petits
?status=shipped, ?price_gte=10&price_lte=100?sort=-created_at (- = descendant)?fields=id,nameuserId + roles, pas l'objet user entierAuthorization: Bearer {token} — jamais en query param (visible dans les logs)Requête → 401 → intercepteur attrape → POST /api/auth/refresh (credentials: include)
→ nouveau token → retry requête originale (transparent pour l'UI)
* avec credentialscredentials: 'include' pour envoyer les cookies cross-domain(A, B, C) sert A et A+B, pas B seultenant_id dans chaque table, leftmost dans composite indexPool size de départ : (CPU cores x 2) + nombre de disques
| Besoin | Solution |
|---|---|
| Server → Client uniquement | SSE (le plus simple, passe les proxies) |
| Bidirectionnel | WebSocket (heartbeat + reconnection obligatoires) |
| Polling simple | React Query refetchInterval (pas d'infra) |
| Taille | Solution |
|---|---|
| > 5MB | Presigned URL → upload direct S3 → sauver la référence (zéro charge serveur) |
| < 5MB | Multipart form → stream through server |
// Créer des erreurs typées par domaine
class NotFoundError extends AppError { status = 404 }
class ValidationError extends AppError { status = 422 }
// Global middleware attrape tout
app.use((err, req, res, next) => {
if (err instanceof AppError) {
// Opérationnel → réponse structurée
return res.status(err.status).json(err.toRFC9457())
}
// Inattendu → log + 500 générique
logger.error({ err, requestId: req.id })
res.status(500).json({ title: 'Internal Server Error', request_id: req.id })
})
| Ne pas faire | Faire |
|---|---|
| Business logic dans les controllers | Service layer |
process.env partout | Config centralisée typée |
| Erreurs génériques | Hiérarchie d'erreurs typées |
| DB direct dans controllers | Repository pattern |
| Pas de validation | Zod/Pydantic à la frontière |
console.log | Logger JSON structuré |
| URL API hardcodée | Variable d'environnement |
| JWT dans localStorage | Memory + cookie httpOnly |
| Erreurs API brutes au client | Messages human-readable |
| Skip loading states | Skeleton/spinner |
/health liveness, /ready readiness)*