skills/nestjs/nestjs-controllers-services/SKILL.md
Separate Controllers from Services and build Custom Decorators in NestJS. Use when defining NestJS controllers, services, or custom parameter decorators.
npx skillsauth add hoangnguyen0403/agent-skills-standard nestjs-controllers-servicesInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
ExecutionContext helpers (switchToHttp()) for platform-agnostic code.@Request() req -> req.user (Not type-safe).@CurrentUser(), @DeviceIp().import { RequestWithUser } from 'src/common/interfaces/request.interface';
export const CurrentUser = createParamDecorator(
(data: unknown, ctx: ExecutionContext): User => {
const request = ctx.switchToHttp().getRequest<RequestWithUser>();
return request.user;
},
);
whitelist: true: Strip properties without decorators.forbidNonWhitelisted: true: Throw error if unknown properties exist.transform: true: Auto-convert primitives (String '1' -> Number 1) and instantiate DTO classes.@nestjs/swagger CLI plugin in nest-cli.json auto-detects DTO properties — no manual @ApiProperty().map() wraps success responses (e.g. { data: T }).PageDto and ApiResponse.catchError() maps low-level errors (DB constraints) to HttpException (e.g. ConflictException) before global filter.Scope.REQUEST.ValidationPipe globally.ParseIntPipe, ParseUUIDPipe on all ID parameters.@Get(':id')
findOne(@Param('id', ParseIntPipe) id: number) { ... }
OnModuleInit for connection setup.OnApplicationShutdown for cleanup. (Requires enableShutdownHooks()).@CurrentUser() decorator instead of accessing raw req.development
Summarizes GitHub PR, GitLab MR, or Azure DevOps PR metadata, review threads, changed files, and template completeness. Use during review-ticket or code-review workflows when PR/MR context exists.
tools
Development tools, linting, and build config for TypeScript. Use when configuring ESLint, Prettier, Jest, Vitest, tsconfig, or any TS build tooling.
development
Validate input, secure auth tokens, and prevent injection attacks in TypeScript. Use when validating input, handling auth tokens, sanitizing data, or managing secrets and sensitive configuration.
development
Apply modern TypeScript standards for type safety and maintainability. Use when working with types, interfaces, generics, enums, unions, or tsconfig settings.