import { Injectable, CanActivate, ExecutionContext } from '@nestjs/common'; import { Reflector } from '@nestjs/core'; import { ROLES_KEY, UserRole } from '../decorators/roles.decorator'; /** * Guard para verificar roles de usuario. * Usar junto con @Roles() decorator. * * @example * @Roles(UserRole.ADMIN) * @UseGuards(JwtAuthGuard, RolesGuard) * @Controller('admin') * export class AdminController {} */ @Injectable() export class RolesGuard implements CanActivate { constructor(private reflector: Reflector) {} canActivate(context: ExecutionContext): boolean { const requiredRoles = this.reflector.getAllAndOverride( ROLES_KEY, [context.getHandler(), context.getClass()], ); // Si no hay roles definidos, permitir acceso if (!requiredRoles || requiredRoles.length === 0) { return true; } const { user } = context.switchToHttp().getRequest(); if (!user || !user.role) { return false; } return requiredRoles.includes(user.role); } }