← スキル一覧に戻る

nestjs-controllers-services
by HoangNguyen0403
nestjs-controllers-servicesは、other分野における実用的なスキルです。複雑な課題への対応力を強化し、業務効率と成果の質を改善します。
⭐ 111🍴 40📅 2026年1月23日
SKILL.md
name: NestJS Controllers & Services description: Controller/Service separation and Custom Decorators. metadata: labels: [nestjs, controller, service] triggers: files: ['/*.controller.ts', '/*.service.ts'] keywords: [Controller, Injectable, ExecutionContext, createParamDecorator]
NestJS Controllers & Services Standards
Priority: P0 (FOUNDATIONAL)
Layer separation standards and dependency injection patterns for NestJS applications.
Controllers
-
Role: Handler only. Delegate all logic to Services.
-
Context: Use
ExecutionContexthelpers (switchToHttp()) for platform-agnostic code. -
Custom Decorators:
- Avoid:
@Request() req->req.user(Not type-safe). - Pattern: Create typed decorators like
@CurrentUser(),@DeviceIp().
export const CurrentUser = createParamDecorator( (data: unknown, ctx: ExecutionContext) => ctx.switchToHttp().getRequest().user, ); - Avoid:
DTOs & Validation
- Strictness:
whitelist: true: Strip properties without decorators.- Critical:
forbidNonWhitelisted: true: Throw error if unknown properties exist.
- Transformation:
transform: true: Auto-convert primitives (String '1' -> Number 1) and instantiate DTO classes.
- Documentation:
- Automation: Use the
@nestjs/swaggerCLI plugin (nest-cli.json) to auto-detect DTO properties without manual@ApiProperty()tags.
- Automation: Use the
Interceptors (Response Mapping)
- Standardization: specific responses should be mapped in Interceptors, not Controllers.
- Use
map()to wrap success responses (e.g.{ data: T }). - Refer to API Standards for
PageDtoandApiResponse. - Use
catchError()to map low-level errors (DB constraints) toHttpException(e.g.ConflictException) before they hit the global filter.
- Use
Services & Business Logic
- Singleton: Default.
- Stateless: Do not store request-specific state in class properties unless identifying as
Scope.REQUEST.
Pipes & Validation
- Global: Register
ValidationPipeglobally. - Route Params: Fail fast. Always use
ParseIntPipe,ParseUUIDPipeon all ID parameters.
@Get(':id')
findOne(@Param('id', ParseIntPipe) id: number) { ... }
Lifecycle Events
- Init: Use
OnModuleInitfor connection setup. - Destroy: Use
OnApplicationShutdownfor cleanup. (RequiresenableShutdownHooks()).
スコア
総合スコア
85/100
リポジトリの品質指標に基づく評価
✓SKILL.md
SKILL.mdファイルが含まれている
+20
✓LICENSE
ライセンスが設定されている
+10
✓説明文
100文字以上の説明がある
+10
✓人気
GitHub Stars 100以上
+5
✓最近の活動
1ヶ月以内に更新
+10
✓フォーク
10回以上フォークされている
+5
✓Issue管理
オープンIssueが50未満
+5
✓言語
プログラミング言語が設定されている
+5
✓タグ
1つ以上のタグが設定されている
+5
レビュー
💬
レビュー機能は近日公開予定です

