using Netina.Core.EntityServices.Abstracts; namespace Netina.Api.Controllers; public class RoleController : ICarterModule { public void AddRoutes(IEndpointRouteBuilder app) { var group = app.NewVersionedApi("Roles") .MapGroup($"api/user/role"); group.MapGet("", GetAllAsync) .WithDisplayName("GetAllRoles") .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ViewRoles, ApplicationPermission.ManageRoles)) .HasApiVersion(1.0); group.MapGet("permission", GetAllPermissions) .WithDisplayName("GetAllPermissions") .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ViewRoles, ApplicationPermission.ManageRoles)) .HasApiVersion(1.0); group.MapGet("{id}", GetAsync) .WithDisplayName("GetRole") .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ViewRoles, ApplicationPermission.ManageRoles)) .HasApiVersion(1.0); group.MapPost("", Post) .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ManageRoles)) .HasApiVersion(1.0); group.MapPut("", Put) .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ManageRoles)) .HasApiVersion(1.0); group.MapDelete("{id}", Delete) .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ManageRoles)) .HasApiVersion(1.0); } // GET:Get All Entity public async Task GetAllAsync([FromQuery] int? page, [FromQuery]string? roleName, IUserService userService, CancellationToken cancellationToken) => TypedResults.Ok(await userService.GetRolesAsync(page,roleName, cancellationToken)); // GET:Get An Entity By Id public async Task GetAsync(Guid id, IUserService userService, CancellationToken cancellationToken) => TypedResults.Ok(await userService.GetRoleAsync(id, cancellationToken)); // POST:Create Entity public async Task Post([FromBody] RoleActionRequestDto request, IUserService userService, CancellationToken cancellationToken) => TypedResults.Ok(await userService.CreateRoleAsync(request, cancellationToken)); // PUT:Update Entity public async Task Put([FromBody] RoleActionRequestDto request, IUserService userService, CancellationToken cancellationToken) => TypedResults.Ok(await userService.EditRoleAsync(request, cancellationToken)); // DELETE:Delete Entity public async Task Delete(Guid id, IUserService userService, CancellationToken cancellationToken) => TypedResults.Ok(await userService.RemoveRoleAsync(id, cancellationToken)); // DELETE:Delete Entity public async Task GetAllPermissions(IUserService userService) => TypedResults.Ok(userService.GetPermissions()); }