feat(app): BATCH 3 - handlers permisos con TDD [UDT-005]

This commit is contained in:
2026-04-15 15:31:26 -03:00
parent 7ddb71c24c
commit 704794a2e2
14 changed files with 469 additions and 0 deletions

View File

@@ -0,0 +1,30 @@
using SIGCM2.Application.Abstractions;
using SIGCM2.Application.Abstractions.Persistence;
using SIGCM2.Application.Permisos.Dtos;
using SIGCM2.Domain.Exceptions;
namespace SIGCM2.Application.Permisos.GetByRol;
public sealed class GetRolPermisosQueryHandler : ICommandHandler<GetRolPermisosQuery, IReadOnlyList<PermisoDto>>
{
private readonly IRolRepository _rolRepository;
private readonly IRolPermisoRepository _rolPermisoRepository;
public GetRolPermisosQueryHandler(IRolRepository rolRepository, IRolPermisoRepository rolPermisoRepository)
{
_rolRepository = rolRepository;
_rolPermisoRepository = rolPermisoRepository;
}
public async Task<IReadOnlyList<PermisoDto>> Handle(GetRolPermisosQuery query)
{
var rol = await _rolRepository.GetByCodigoAsync(query.RolCodigo);
if (rol is null)
throw new RolNotFoundException(query.RolCodigo);
var permisos = await _rolPermisoRepository.GetByRolCodigoAsync(query.RolCodigo);
return permisos
.Select(p => new PermisoDto(p.Id, p.Codigo, p.Nombre, p.Descripcion, p.Modulo))
.ToList();
}
}