Handler.cs 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152
  1. using Application.Abstractions.Messaging;
  2. using Application.Abstractions.Data;
  3. using SharedKernel.Storage;
  4. using Microsoft.EntityFrameworkCore;
  5. namespace Application.Features.Forum.Post.Delete;
  6. public sealed class Handler(IAppDbContext db, IFileStorage fileStorage) : ICommandHandler<Command>
  7. {
  8. public async Task Handle(Command request, CancellationToken ct)
  9. {
  10. if (request.IDs is null || request.IDs.Length == 0)
  11. {
  12. return;
  13. }
  14. var posts = await db.Post.Where(c => request.IDs.Contains(c.ID)).ToListAsync(ct);
  15. // 썸네일 파일 삭제
  16. foreach (var post in posts)
  17. {
  18. if (!string.IsNullOrEmpty(post.Thumbnail))
  19. {
  20. fileStorage.DeleteByUrl(post.Thumbnail);
  21. }
  22. }
  23. // Board/BoardGroup 카운트 감소
  24. var boardIDs = posts.Select(c => c.BoardID).Distinct().ToList();
  25. var boards = await db.Board.Where(c => boardIDs.Contains(c.ID)).ToListAsync(ct);
  26. var groupIDs = boards.Select(c => c.BoardGroupID).Distinct().ToList();
  27. var groups = await db.BoardGroup.Where(c => groupIDs.Contains(c.ID)).ToListAsync(ct);
  28. foreach (var board in boards)
  29. {
  30. var count = posts.Count(c => c.BoardID == board.ID);
  31. board.Posts -= count;
  32. board.UpdatedAt = DateTime.UtcNow;
  33. }
  34. foreach (var group in groups)
  35. {
  36. var relatedBoards = boards.Where(b => b.BoardGroupID == group.ID).Select(b => b.ID).ToList();
  37. var count = posts.Count(c => relatedBoards.Contains(c.BoardID));
  38. group.Posts -= count;
  39. group.UpdatedAt = DateTime.UtcNow;
  40. }
  41. db.Post.RemoveRange(posts);
  42. await db.SaveChangesAsync(ct);
  43. }
  44. }