namespace Netina.Api.Controllers; public class DiscountController : ICarterModule { public virtual void AddRoutes(IEndpointRouteBuilder app) { var group = app.NewVersionedApi("Discount") .MapGroup($"api/discount") .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser()); group.MapGet("", GetAllAsync) .WithDisplayName("Get Discounts") .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ManageDiscounts, ApplicationPermission.ViewDiscounts)) .HasApiVersion(1.0); group.MapGet("{id}", GetAsync) .WithDisplayName("Get Discount") .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ManageDiscounts, ApplicationPermission.ViewDiscounts)) .HasApiVersion(1.0); group.MapPost("", Post) .HasApiVersion(1.0) .WithDisplayName("Create Discount") .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ManageDiscounts)); group.MapPut("", Put) .HasApiVersion(1.0) .WithDisplayName("Update Discount") .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ManageDiscounts)); group.MapDelete("{id}", Delete) .HasApiVersion(1.0) .WithDisplayName("Delete Discount") .RequireAuthorization(builder => builder.AddAuthenticationSchemes("Bearer").RequireAuthenticatedUser().RequireClaim(CustomClaimType.Permission, ApplicationPermission.ManageDiscounts)); } // GET:Get All Entity private async Task GetAllAsync([FromQuery] int page, IMediator mediator, CancellationToken cancellationToken) => TypedResults.Ok(await mediator.Send(new GetDiscountsQuery(page), cancellationToken)); // GET:Get An Entity By Id private async Task GetAsync(Guid id, IMediator mediator, CancellationToken cancellationToken) => TypedResults.Ok(await mediator.Send(new GetDiscountQuery(id), cancellationToken)); // POST:Create Entity private async Task Post([FromBody] CreateDiscountCommand request, IMediator mediator, CancellationToken cancellationToken) => TypedResults.Ok(await mediator.Send(request, cancellationToken)); // PUT:Update Entity private async Task Put([FromBody] UpdateDiscountCommand request, IMediator mediator, CancellationToken cancellationToken) => TypedResults.Ok(await mediator.Send(request, cancellationToken)); // DELETE:Delete Entity private async Task Delete(Guid id, IMediator mediator, CancellationToken cancellationToken) => TypedResults.Ok(await mediator.Send(new DeleteDiscountCommand(id), cancellationToken)); }