using MediatR; using Web.Api.Common; using Web.Api.Extensions; using Microsoft.AspNetCore.Mvc; using System.Security.Claims; namespace Web.Api.Endpoints.Forum.Post; internal sealed class Update : IEndpoint { public sealed class Request { public int? PostID { get; set; } public int? BoardID { get; set; } public string? BoardCode { get; set; } public int? BoardPrefixID { get; set; } public required string Subject { get; set; } public required string Content { get; set; } public bool IsSecret { get; set; } public bool IsNotice { get; set; } public bool IsSpeaker { get; set; } public List? Tags { get; set; } public List? Medias { get; set; } } public void MapEndpoint(IEndpointRouteBuilder app) { app.MapPut("api/forum/posts/{id}", async ( int id, ClaimsPrincipal user, [FromForm] Request request, HttpRequest httpRequest, ISender sender, CancellationToken ct ) => { var memberID = user.GetMemberID(); if (memberID is null) { return ApiResponse.Fail(StatusCodes.Status401Unauthorized, "Invalid token"); } var images = httpRequest.Form.Files.GetFiles("images").ToList(); var files = httpRequest.Form.Files.GetFiles("files").ToList(); var command = new Application.Features.Api.Forum.Post.Update.Command( id, memberID.Value, request.BoardPrefixID, request.Subject, request.Content, request.IsSecret, request.IsNotice, request.IsSpeaker, request.Tags, images.Count > 0 ? images : null, request.Medias, files.Count > 0 ? files : null ); var result = await sender.Send(command, ct); return result.Match( () => ApiResponse.Ok(), CustomResults.Problem ); }) .WithTags("Forum") .RequireAuthorization() .DisableAntiforgery(); } }