Handler.cs 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. using Application.Abstractions.Data;
  2. using Application.Abstractions.Messaging;
  3. using Microsoft.EntityFrameworkCore;
  4. namespace Application.Features.Forum.PostFile.Search;
  5. public sealed class Handler(IAppDbContext db) : IQueryHandler<Query, Response>
  6. {
  7. public async Task<Response> Handle(Query request, CancellationToken ct)
  8. {
  9. var query = db.PostFile.AsNoTracking().Include(c => c.Board).Include(c => c.Post).AsQueryable();
  10. if (request.BoardID.HasValue)
  11. {
  12. query = query.Where(c => c.BoardID == request.BoardID.Value);
  13. }
  14. if (request.PostID.HasValue)
  15. {
  16. query = query.Where(c => c.PostID == request.PostID.Value);
  17. }
  18. if (!string.IsNullOrWhiteSpace(request.Keyword))
  19. {
  20. var kw = request.Keyword.Trim();
  21. query = request.Search switch
  22. {
  23. 1 => query.Where(c => c.PostID.ToString().Contains(kw)),
  24. 2 => query.Where(c => c.Post.Subject.Contains(kw)),
  25. 3 => query.Where(c => (c.Post.Name != null && c.Post.Name.Contains(kw)) || (c.Post.SID != null && c.Post.SID.Contains(kw))),
  26. _ => query.Where(c => c.Post.Subject.Contains(kw))
  27. };
  28. }
  29. if (request.IsDisabled.HasValue)
  30. {
  31. query = query.Where(c => c.IsDisabled == request.IsDisabled.Value);
  32. }
  33. if (!string.IsNullOrWhiteSpace(request.StartAt) && DateTime.TryParse(request.StartAt, out var startDate))
  34. {
  35. query = query.Where(c => c.CreatedAt >= startDate);
  36. }
  37. if (!string.IsNullOrWhiteSpace(request.EndAt) && DateTime.TryParse(request.EndAt, out var endDate))
  38. {
  39. query = query.Where(c => c.CreatedAt <= endDate.AddDays(1));
  40. }
  41. query = query.OrderByDescending(c => c.ID);
  42. var total = await query.CountAsync(ct);
  43. var list = await query
  44. .Skip((request.PageNum - 1) * request.PerPage)
  45. .Take(request.PerPage)
  46. .Select(c => new
  47. {
  48. c.ID,
  49. c.BoardID,
  50. BoardName = c.Board.Name,
  51. c.PostID,
  52. PostSubject = c.Post.Subject,
  53. c.FileName,
  54. c.Url,
  55. c.Extension,
  56. c.Size,
  57. c.Downloads,
  58. c.IsDisabled,
  59. c.CreatedAt
  60. })
  61. .ToListAsync(ct);
  62. var startNum = total - ((request.PageNum - 1) * request.PerPage);
  63. return new Response(
  64. total,
  65. [..list.Select((c, i) => new Response.Row(
  66. Num: startNum - i,
  67. c.ID,
  68. c.BoardID,
  69. c.BoardName,
  70. c.PostID,
  71. c.PostSubject,
  72. c.FileName,
  73. c.Url,
  74. c.Extension,
  75. c.Size,
  76. c.Downloads,
  77. c.IsDisabled,
  78. c.CreatedAt
  79. ))]
  80. );
  81. }
  82. }