using Application.Abstractions.Data; using Application.Abstractions.Messaging; using Microsoft.EntityFrameworkCore; namespace Application.Features.Forum.Trash.Comment.PermanentDelete; public sealed class Handler(IAppDbContext db) : ICommandHandler { public async Task Handle(Command request, CancellationToken ct) { if (request.IDs is null || request.IDs.Length == 0) { return; } var comments = await db.Comment .Where(c => request.IDs.Contains(c.ID) && c.IsDeleted) .ToListAsync(ct); var postIDs = comments.Select(c => c.PostID).Distinct().ToList(); var posts = await db.Post.Where(c => postIDs.Contains(c.ID)).ToListAsync(ct); foreach (var post in posts) { var count = comments.Count(c => c.PostID == post.ID); post.Comments -= count; post.UpdatedAt = DateTime.UtcNow; } var boardIDs = comments.Select(c => c.BoardID).Distinct().ToList(); var boards = await db.Board.Where(c => boardIDs.Contains(c.ID)).ToListAsync(ct); foreach (var board in boards) { var count = comments.Count(c => c.BoardID == board.ID); board.Comments -= count; board.UpdatedAt = DateTime.UtcNow; } db.Comment.RemoveRange(comments); await db.SaveChangesAsync(ct); } }