Comprehensive developer toolkit providing reusable skills for Java/Spring Boot, TypeScript/NestJS/React/Next.js, Python, PHP, AWS CloudFormation, AI/RAG, DevOps, and more.
89
89%
Does it follow best practices?
Impact
Pending
No eval scenarios have been run
Risky
Do not use without reviewing
Enforce security best practices for NestJS applications: JWT authentication, guard-based authorization, input validation, rate limiting, and output sanitization.
@nestjs/jwt with @nestjs/passport — never hardcode secretsConfigService via JwtModule.registerAsync()sub, email, roles)// ✅ Secure JWT configuration
JwtModule.registerAsync({
imports: [ConfigModule],
inject: [ConfigService],
useFactory: (config: ConfigService) => ({
secret: config.get<string>('JWT_SECRET'),
signOptions: {
expiresIn: '15m',
issuer: config.get<string>('JWT_ISSUER'),
},
}),
});
// ✅ Validate user on every request
async validate(payload: JwtPayload): Promise<User> {
const user = await this.usersService.findById(payload.sub);
if (!user || !user.isActive) {
throw new UnauthorizedException('User not found or inactive');
}
return user;
}JwtAuthGuard and RolesGuard globally via APP_GUARD@Public() decorator to opt-out specific routes from authentication@Roles() decorator for role-based access control// ✅ Declarative access control
@Controller('admin')
@Roles(Role.Admin)
export class AdminController {
@Get('users')
getUsers(): Promise<User[]> { ... }
@Delete('users/:id')
deleteUser(@Param('id') id: string): Promise<void> { ... }
@Public()
@Get('health')
health(): { status: string } {
return { status: 'ok' };
}
}class-validator decorators on DTOsValidationPipe with whitelist: true and forbidNonWhitelisted: trueParseUUIDPipe)@Transform() for input sanitization (trim, lowercase emails)// ✅ Well-validated DTO
export class CreateUserDto {
@IsString()
@IsNotEmpty()
@MinLength(2)
@MaxLength(100)
@Transform(({ value }) => value?.trim())
name: string;
@IsEmail()
@Transform(({ value }) => value?.toLowerCase().trim())
email: string;
@IsString()
@MinLength(8)
@Matches(/^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)/, {
message: 'Password must contain uppercase, lowercase, and number',
})
password: string;
}@nestjs/throttler to limit request rates — apply globally via APP_GUARD@SkipThrottle() for health checks and internal endpoints@Throttle() for fine-grained control// ✅ Global throttler with multiple windows
ThrottlerModule.forRoot([
{ name: 'short', ttl: 1000, limit: 3 },
{ name: 'medium', ttl: 10000, limit: 20 },
{ name: 'long', ttl: 60000, limit: 100 },
]);
// ✅ Strict limits for sensitive endpoints
@Post('login')
@Throttle({ short: { limit: 5, ttl: 60000 } })
async login(@Body() dto: LoginDto): Promise<TokenResponse> { ... }
@Post('forgot-password')
@Throttle({ short: { limit: 3, ttl: 3600000 } })
async forgotPassword(@Body() dto: ForgotPasswordDto): Promise<void> { ... }sanitize-html@Transform() in DTOs to strip or whitelist HTML tagsContent-Type: application/json headershelmet middleware for CSP headers// ✅ Sanitize on input
export class CreatePostDto {
@IsString()
@Transform(({ value }) => sanitizeHtml(value, { allowedTags: [] }))
title: string;
@IsString()
@Transform(({ value }) =>
sanitizeHtml(value, {
allowedTags: ['p', 'br', 'b', 'i', 'a'],
allowedAttributes: { a: ['href'] },
}),
)
content: string;
}
// ✅ Helmet with CSP
app.use(
helmet({
contentSecurityPolicy: {
directives: {
defaultSrc: ["'self'"],
scriptSrc: ["'self'"],
},
},
}),
);// Secure controller with guards, validated input, and safe output
@Controller('users')
export class UsersController {
@Post()
create(@Body() dto: CreateUserDto): Promise<UserResponseDto> {
return this.usersService.create(dto);
}
@Get(':id')
findOne(@Param('id', ParseUUIDPipe) id: string): Promise<UserResponseDto> {
return this.usersService.findOne(id);
}
}@Controller('users')
export class UsersController {
@Post()
create(@Body() body: any) {
// No validation, no DTO, accepts anything
return this.usersService.create(body);
}
@Get(':id')
async findOne(@Param('id') id: string) {
const user = await this.usersService.findById(id);
if (!user) {
// Reflects raw user input in error — XSS risk
throw new NotFoundException(`User ${id} not found`);
}
return user; // Returns entity directly — exposes sensitive fields
}
}docs
plugins
developer-kit-ai
developer-kit-aws
agents
docs
skills
aws
aws-cli-beast
aws-cost-optimization
aws-drawio-architecture-diagrams
aws-sam-bootstrap
aws-cloudformation
aws-cloudformation-auto-scaling
aws-cloudformation-bedrock
aws-cloudformation-cloudfront
aws-cloudformation-cloudwatch
aws-cloudformation-dynamodb
aws-cloudformation-ec2
aws-cloudformation-ecs
aws-cloudformation-elasticache
references
aws-cloudformation-iam
references
aws-cloudformation-lambda
aws-cloudformation-rds
aws-cloudformation-s3
aws-cloudformation-security
aws-cloudformation-task-ecs-deploy-gh
aws-cloudformation-vpc
references
developer-kit-core
agents
commands
skills
developer-kit-devops
developer-kit-java
agents
commands
docs
skills
aws-lambda-java-integration
aws-rds-spring-boot-integration
aws-sdk-java-v2-bedrock
aws-sdk-java-v2-core
aws-sdk-java-v2-dynamodb
aws-sdk-java-v2-kms
aws-sdk-java-v2-lambda
aws-sdk-java-v2-messaging
aws-sdk-java-v2-rds
aws-sdk-java-v2-s3
aws-sdk-java-v2-secrets-manager
clean-architecture
graalvm-native-image
langchain4j-ai-services-patterns
references
langchain4j-mcp-server-patterns
references
langchain4j-rag-implementation-patterns
references
langchain4j-spring-boot-integration
langchain4j-testing-strategies
langchain4j-tool-function-calling-patterns
langchain4j-vector-stores-configuration
references
qdrant
references
spring-ai-mcp-server-patterns
spring-boot-actuator
spring-boot-cache
spring-boot-crud-patterns
spring-boot-dependency-injection
spring-boot-event-driven-patterns
spring-boot-openapi-documentation
spring-boot-project-creator
spring-boot-resilience4j
spring-boot-rest-api-standards
spring-boot-saga-pattern
spring-boot-security-jwt
assets
references
scripts
spring-boot-test-patterns
spring-data-jpa
references
spring-data-neo4j
references
unit-test-application-events
unit-test-bean-validation
unit-test-boundary-conditions
unit-test-caching
unit-test-config-properties
references
unit-test-controller-layer
unit-test-exception-handler
references
unit-test-json-serialization
unit-test-mapper-converter
references
unit-test-parameterized
unit-test-scheduled-async
references
unit-test-service-layer
references
unit-test-utility-methods
unit-test-wiremock-rest-api
references
developer-kit-php
developer-kit-project-management
developer-kit-python
developer-kit-specs
commands
docs
hooks
test-templates
tests
skills
developer-kit-tools
developer-kit-typescript
agents
docs
hooks
rules
skills
aws-cdk
aws-lambda-typescript-integration
better-auth
clean-architecture
drizzle-orm-patterns
dynamodb-toolbox-patterns
references
nestjs
nestjs-best-practices
nestjs-code-review
nestjs-drizzle-crud-generator
nextjs-app-router
nextjs-authentication
nextjs-code-review
nextjs-data-fetching
nextjs-deployment
nextjs-performance
nx-monorepo
react-code-review
react-patterns
shadcn-ui
tailwind-css-patterns
tailwind-design-system
references
turborepo-monorepo
typescript-docs
typescript-security-review
zod-validation-utilities
references
github-spec-kit