using System.Security.Claims; using MediatR; using Web.Api.Common; using Web.Api.Extensions; namespace Web.Api.Endpoints.Forum.Comment; internal sealed class Create : IEndpoint { public sealed record Request( int BoardID, int PostID, int? ParentID, string Content, bool IsSecret ); public void MapEndpoint(IEndpointRouteBuilder app) { app.MapPost("api/forum/comments", async ( ClaimsPrincipal user, Request request, ISender sender, CancellationToken ct ) => { var memberID = user.GetMemberID(); if (memberID is null) { return ApiResponse.Fail(StatusCodes.Status401Unauthorized, "Invalid token"); } var command = new Application.Features.Api.Forum.Comment.Create.Command( memberID.Value, request.BoardID, request.PostID, request.ParentID, request.Content, request.IsSecret ); var result = await sender.Send(command, ct); return result.Match( commentID => ApiResponse.Created(new { id = commentID }), CustomResults.Problem ); }) .WithTags("Forum") .RequireAuthorization(); } }