Handler.cs 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. using Application.Abstractions.Data;
  2. using Application.Abstractions.Messaging;
  3. using SharedKernel.Results;
  4. using Microsoft.EntityFrameworkCore;
  5. namespace Application.Features.Api.MyPage.GetPosts;
  6. internal sealed class Handler(IAppDbContext db) : IQueryHandler<Query, Result<Response>>
  7. {
  8. public async Task<Result<Response>> Handle(Query request, CancellationToken ct)
  9. {
  10. var page = request.Page < 1 ? 1 : request.Page;
  11. var perPage = request.PerPage is < 1 or > 50 ? 20 : request.PerPage;
  12. var query = db.Post.AsNoTracking().Where(p => p.MemberID == request.MemberID && !p.IsDeleted).OrderByDescending(p => p.ID);
  13. var total = await query.CountAsync(ct);
  14. var list = await query
  15. .Skip((page - 1) * perPage)
  16. .Take(perPage)
  17. .Select(p => new
  18. {
  19. p.ID,
  20. p.BoardID,
  21. BoardName = p.Board.Name,
  22. p.Subject,
  23. p.Views,
  24. p.Likes,
  25. p.Comments,
  26. p.CreatedAt
  27. })
  28. .ToListAsync(ct);
  29. var startNum = total - ((page - 1) * perPage);
  30. return Result.Success(new Response(
  31. [..list.Select((p, i) => new PostItem(
  32. Num: startNum - i,
  33. p.ID,
  34. p.BoardID,
  35. p.BoardName,
  36. p.Subject,
  37. p.Views,
  38. p.Likes,
  39. p.Comments,
  40. p.CreatedAt
  41. ))],
  42. total,
  43. page,
  44. perPage
  45. ));
  46. }
  47. }