Handler.cs 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768
  1. using Application.Abstractions.Data;
  2. using Application.Abstractions.Messaging;
  3. using Microsoft.EntityFrameworkCore;
  4. using SharedKernel.Storage;
  5. namespace Application.Features.Admin.Forum.Trash.Post.PermanentDelete;
  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) && c.IsDeleted).ToListAsync(ct);
  15. if (posts.Count == 0)
  16. {
  17. return;
  18. }
  19. foreach (var post in posts)
  20. {
  21. if (!string.IsNullOrEmpty(post.Thumbnail))
  22. {
  23. fileStorage.DeleteByUrl(post.Thumbnail);
  24. }
  25. }
  26. var postIDs = posts.Select(c => c.ID).ToList();
  27. // 로그 테이블 선삭제 (Restrict FK 충돌 방지)
  28. // Post 로그
  29. var postFileDownLogs = await db.PostFileDownLog.Where(c => postIDs.Contains(c.PostID)).ToListAsync(ct);
  30. if (postFileDownLogs.Count > 0)
  31. {
  32. db.PostFileDownLog.RemoveRange(postFileDownLogs);
  33. }
  34. var postLinkClickLogs = await db.PostLinkClickLog.Where(c => postIDs.Contains(c.PostID)).ToListAsync(ct);
  35. if (postLinkClickLogs.Count > 0)
  36. {
  37. db.PostLinkClickLog.RemoveRange(postLinkClickLogs);
  38. }
  39. // Comment 로그 (Post → Comment Cascade 시 충돌 방지)
  40. var commentIDs = await db.Comment.Where(c => postIDs.Contains(c.PostID)).Select(c => c.ID).ToListAsync(ct);
  41. if (commentIDs.Count > 0)
  42. {
  43. var commentFileDownLogs = await db.CommentFileDownLog.Where(c => commentIDs.Contains(c.CommentID)).ToListAsync(ct);
  44. if (commentFileDownLogs.Count > 0)
  45. {
  46. db.CommentFileDownLog.RemoveRange(commentFileDownLogs);
  47. }
  48. var commentLinkClickLogs = await db.CommentLinkClickLog.Where(c => commentIDs.Contains(c.CommentID)).ToListAsync(ct);
  49. if (commentLinkClickLogs.Count > 0)
  50. {
  51. db.CommentLinkClickLog.RemoveRange(commentLinkClickLogs);
  52. }
  53. }
  54. db.Post.RemoveRange(posts);
  55. await db.SaveChangesAsync(ct);
  56. }
  57. }