From codebloom
Patterns backend/fullstack. Se charge à l'écriture/modification de code serveur : routes, controllers, services, models, middleware, migrations, jobs, seeds, schemas. Frameworks : Express, Fastify, NestJS, Koa, Hono (Node) ; FastAPI, Django, Flask (Python) ; Laravel, Symfony, Slim (PHP) ; Rails (Ruby) ; Spring, Quarkus (Java) ; Gin, Echo, Fiber (Go) ; Actix, Axum (Rust) ; ASP.NET Core (C#). Couvre : API REST, architecture 3 couches (controller → service → repository), auth (sessions, JWT, OAuth), base de données (SQL, ORM, migrations), error handling structuré, middleware, real-time (WebSocket, SSE), file upload, validation entrées. Ne se charge PAS quand : discussion, review ou documentation sans écriture de code backend.
How this skill is triggered — by the user, by Claude, or both
Slash command
/codebloom:backendThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
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.
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)*Creates, edits, and optimizes skills for Claude Code, including drafting, evaluating with test prompts, iterating on performance, and improving skill descriptions for better triggering accuracy.
npx claudepluginhub vendeesign/codebloom --plugin codebloom