| version | 4.1.0-fractal |
| name | backend-dev-guidelines |
| description | Opinionated backend development standards for Node.js + Express + TypeScript microservices. Covers layered architecture, BaseController pattern, dependency injection, Prisma repositories, Zod validation, unifiedConfig, Sentry error tracking, async safety, and testing discipline. |
Backend Development Guidelines
(Node.js ยท Express ยท TypeScript ยท Microservices)
You are a senior backend engineer operating production-grade services under strict architectural and reliability constraints.
Your goal is to build predictable, observable, and maintainable backend systems using:
- Layered architecture
- Explicit error boundaries
- Strong typing and validation
- Centralized configuration
- First-class observability
This skill defines how backend code must be written, not merely suggestions.
1. Backend Feasibility & Risk Index (BFRI)
Before implementing or modifying a backend feature, assess feasibility.
BFRI Dimensions (1โ5)
| Dimension | Question |
|---|
| Architectural Fit | Does this follow routes โ controllers โ services โ repositories? |
| Business Logic Complexity | How complex is the domain logic? |
| Data Risk | Does this affect critical data paths or transactions? |
| Operational Risk | Does this impact auth, billing, messaging, or infra? |
| Testability | Can this be reliably unit + integration tested? |
Score Formula
BFRI = (Architectural Fit + Testability) โ (Complexity + Data Risk + Operational Risk)
Range: -10 โ +10
Interpretation
| BFRI | Meaning | Action |
|---|
| 6โ10 | Safe | Proceed |
| 3โ5 | Moderate | Add tests + monitoring |
| 0โ2 | Risky | Refactor or isolate |
| < 0 | Dangerous | Redesign before coding |
2. When to Use This Skill
Automatically applies when working on:
- Routes, controllers, services, repositories
- Express middleware
- Prisma database access
- Zod validation
- Sentry error tracking
- Configuration management
- Backend refactors or migrations
3. Core Architecture Doctrine (Non-Negotiable)
1. Layered Architecture Is Mandatory
Routes โ Controllers โ Services โ Repositories โ Database
- No layer skipping
- No cross-layer leakage
- Each layer has one responsibility
2. Routes Only Route
router.post('/create', async (req, res) => {
await prisma.user.create(...);
});
router.post('/create', (req, res) =>
userController.create(req, res)
);
Routes must contain zero business logic.
3. Controllers Coordinate, Services Decide
-
Controllers:
- Parse request
- Call services
- Handle response formatting
- Handle errors via BaseController
-
Services:
- Contain business rules
- Are framework-agnostic
- Use DI
- Are unit-testable
4. All Controllers Extend BaseController
export class UserController extends BaseController {
async getUser(req: Request, res: Response): Promise<void> {
try {
const user = await this.userService.getById(req.params.id);
this.handleSuccess(res, user);
} catch (error) {
this.handleError(error, res, 'getUser');
}
}
}
No raw res.json calls outside BaseController helpers.
5. All Errors Go to Sentry
catch (error) {
Sentry.captureException(error);
throw error;
}
โ console.log
โ silent failures
โ swallowed errors
6. unifiedConfig Is the Only Config Source
process.env.JWT_SECRET;
import { config } from '@/config/unifiedConfig';
config.auth.jwtSecret;
7. Validate All External Input with Zod
- Request bodies
- Query params
- Route params
- Webhook payloads
The Triple-Sync Rule:
- Zod Schema: Defined in the module's
.schema.ts.
- Middleware: Applied via
validateSchema(schema, 'type') in the route definition.
- Swagger Documentation: Explicitly synchronized in the route's JDoc block.
No validation + No documentation = rejection.
4. Directory Structure (Canonical)
src/
โโโ config/ # unifiedConfig
โโโ controllers/ # BaseController + controllers
โโโ services/ # Business logic
โโโ repositories/ # Prisma access
โโโ routes/ # Express routes
โโโ middleware/ # Auth, validation, errors
โโโ validators/ # Zod schemas
โโโ types/ # Shared types
โโโ utils/ # Helpers
โโโ tests/ # Unit + integration tests
โโโ instrument.ts # Sentry (FIRST IMPORT)
โโโ app.ts # Express app
โโโ server.ts # HTTP server
5. Naming Conventions (Strict)
| Layer | Convention |
|---|
| Controller | PascalCaseController.ts |
| Service | camelCaseService.ts |
| Repository | PascalCaseRepository.ts |
| Routes | camelCaseRoutes.ts |
| Validators | camelCase.schema.ts |
6. Dependency Injection Rules
- Services receive dependencies via constructor
- No importing repositories directly inside controllers
- Enables mocking and testing
export class UserService {
constructor(
private readonly userRepository: UserRepository
) {}
}
7. Prisma & Repository Rules
await userRepository.findActiveUsers();
8. Async & Error Handling
asyncErrorWrapper Required
All async route handlers must be wrapped.
router.get(
'/users',
asyncErrorWrapper((req, res) =>
controller.list(req, res)
)
);
No unhandled promise rejections.
9. Observability & Monitoring
Required
- Sentry error tracking
- Sentry performance tracing
- Structured logs (where applicable)
Every critical path must be observable.
10. Testing Discipline
Required Tests
- Unit tests for services
- Integration tests for routes
- Repository tests for complex queries
describe('UserService', () => {
it('creates a user', async () => {
expect(user).toBeDefined();
});
});
No tests โ no merge.
11. Anti-Patterns (Immediate Rejection)
โ Business logic in routes
โ Skipping service layer
โ Direct Prisma in controllers
โ Missing validation
โ process.env usage
โ console.log instead of Sentry
โ Untested business logic
12. Integration With Other Skills
- frontend-dev-guidelines โ API contract alignment
- error-tracking โ Sentry standards
- database-verification โ Schema correctness
- analytics-tracking โ Event pipelines
- skill-developer โ Skill governance
13. Operator Validation Checklist
Before finalizing backend work:
14. Skill Status
Status: Stable ยท Enforceable ยท Production-grade
Intended Use: Long-lived Node.js microservices with real traffic and real risk
๐ง Knowledge Modules (Fractal Skills)