Handler.cs 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. using Application.Abstractions.Data;
  2. using Application.Abstractions.Messaging;
  3. using Domain.Entities.Donations.ValueObject;
  4. using Microsoft.EntityFrameworkCore;
  5. namespace Application.Features.Api.Crew.GetActiveCrewForChannel;
  6. internal sealed class Handler(IAppDbContext db) : IQueryHandler<Query, Response?>
  7. {
  8. public async Task<Response?> Handle(Query request, CancellationToken ct)
  9. {
  10. var channel = await db.Channel.AsNoTracking()
  11. .FirstOrDefaultAsync(c => c.SID == request.ChannelSID, ct);
  12. if (channel is null) return null;
  13. // 채널에 연결된 크루 중 Active 세션이 있는지 확인
  14. var session = await db.CrewSession.AsNoTracking()
  15. .Where(s => s.Status == CrewSessionStatus.Active)
  16. .Join(db.Crew.Where(c => c.ChannelID == channel.ID), s => s.CrewID, c => c.ID, (s, c) => new { Session = s, Crew = c })
  17. .FirstOrDefaultAsync(ct);
  18. if (session is null) return null;
  19. var members = await db.CrewDonationSummary.AsNoTracking()
  20. .Where(s => s.CrewSessionID == session.Session.ID)
  21. .Join(db.CrewMember, s => s.CrewMemberID, m => m.ID, (s, m) => new { Summary = s, Member = m })
  22. .OrderBy(x => x.Summary.Rank)
  23. .Select(x => new CrewMemberInfo(
  24. x.Member.ID,
  25. x.Member.Nickname,
  26. x.Member.Member != null ? x.Member.Member.Thumb : null,
  27. x.Member.Channel != null ? x.Member.Channel.Name : null
  28. ))
  29. .ToListAsync(ct);
  30. return new Response(
  31. session.Session.ID,
  32. session.Session.Title,
  33. session.Crew.Name,
  34. members
  35. );
  36. }
  37. }