Handler.cs 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. using Application.Abstractions.Data;
  2. using Application.Abstractions.Messaging;
  3. using Microsoft.EntityFrameworkCore;
  4. namespace Application.Features.Admin.Forum.Comment.Delete;
  5. public sealed class Handler(IAppDbContext db) : ICommandHandler<Command>
  6. {
  7. public async Task Handle(Command request, CancellationToken ct)
  8. {
  9. if (request.IDs is null || request.IDs.Length == 0)
  10. return;
  11. var comments = await db.Comment
  12. .Where(c => request.IDs.Contains(c.ID))
  13. .ToListAsync(ct);
  14. // 미삭제 댓글만 카운트 감소 (소프트 삭제된 댓글은 이미 카운트가 감소됨)
  15. var activeComments = comments.Where(c => !c.IsDeleted).ToList();
  16. // Post 댓글 카운트 감소
  17. var postIDs = activeComments.Select(c => c.PostID).Distinct().ToList();
  18. var posts = await db.Post.Where(c => postIDs.Contains(c.ID)).ToListAsync(ct);
  19. foreach (var post in posts)
  20. {
  21. var count = activeComments.Count(c => c.PostID == post.ID);
  22. post.Comments -= count;
  23. post.UpdatedAt = DateTime.UtcNow;
  24. }
  25. // Board 댓글 카운트 감소
  26. var boardIDs = activeComments.Select(c => c.BoardID).Distinct().ToList();
  27. var boards = await db.Board.Where(c => boardIDs.Contains(c.ID)).ToListAsync(ct);
  28. foreach (var board in boards)
  29. {
  30. var count = activeComments.Count(c => c.BoardID == board.ID);
  31. board.Comments -= count;
  32. board.UpdatedAt = DateTime.UtcNow;
  33. }
  34. db.Comment.RemoveRange(comments);
  35. await db.SaveChangesAsync(ct);
  36. }
  37. }