| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576 |
- using SharedKernel.Extensions;
- using Application.Abstractions.Data;
- using MediatR;
- using Microsoft.EntityFrameworkCore;
- namespace Application.Features.Member.LoginLog.Search;
- public sealed class Handler(IAppDbContext db) : IRequestHandler<Query, Response>
- {
- public async Task<Response> Handle(Query request, CancellationToken ct)
- {
- var query = db.MemberLoginLog
- .AsNoTracking()
- .Include(x => x.Member)
- .AsQueryable();
- // 필터링
- if (request.MemberId.HasValue)
- {
- query = query.Where(x => x.MemberID == request.MemberId.Value);
- }
- if (!string.IsNullOrWhiteSpace(request.Account))
- {
- query = query.Where(x => x.Account.Contains(request.Account));
- }
- if (request.Success.HasValue)
- {
- query = query.Where(x => x.Success == request.Success.Value);
- }
- var total = await query.CountAsync(ct);
- var skip = (request.PageNum - 1) * request.PerPage;
- var list = await query
- .OrderByDescending(x => x.ID)
- .Skip(skip)
- .Take(request.PerPage)
- .Select(x => new
- {
- x.ID,
- x.MemberID,
- MemberName = x.Member != null ? x.Member.Name : null,
- x.Account,
- x.Success,
- x.Reason,
- x.IpAddress,
- x.UserAgent,
- x.CreatedAt
- })
- .ToListAsync(ct);
- var rows = list
- .Select((x, idx) => new Response.Row
- {
- Num = total - skip - idx,
- ID = x.ID,
- MemberID = x.MemberID,
- MemberName = x.MemberName,
- Account = x.Account,
- Success = x.Success,
- Reason = x.Reason,
- IpAddress = x.IpAddress,
- UserAgent = x.UserAgent,
- CreatedAt = x.CreatedAt.GetDateAt()
- })
- .ToList();
- return new Response
- {
- Total = total,
- List = rows
- };
- }
- }
|