Handler.cs 1.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940
  1. using Application.Abstractions.Data;
  2. using Application.Abstractions.Messaging;
  3. using SharedKernel.Results;
  4. using Microsoft.EntityFrameworkCore;
  5. using Microsoft.Extensions.Logging;
  6. namespace Application.Features.Api.Auth.Logout;
  7. internal sealed class Handler(IAppDbContext db, ILogger<Handler> logger) : ICommandHandler<Command, Result>
  8. {
  9. public async Task<Result> Handle(Command request, CancellationToken ct)
  10. {
  11. // 개별 로그아웃
  12. if (!string.IsNullOrWhiteSpace(request.RefreshToken))
  13. {
  14. var refreshToken = await db.RefreshToken.FirstOrDefaultAsync(t => t.Token == request.RefreshToken && t.MemberID == request.MemberID, ct);
  15. if (refreshToken is not null && !refreshToken.IsRevoked)
  16. {
  17. refreshToken.Revoke();
  18. }
  19. }
  20. else
  21. {
  22. // 전체 로그아웃
  23. var activeTokens = await db.RefreshToken.Where(t => t.MemberID == request.MemberID && !t.IsRevoked).ToListAsync(ct);
  24. foreach (var token in activeTokens)
  25. {
  26. token.Revoke();
  27. }
  28. }
  29. await db.SaveChangesAsync(ct);
  30. logger.LogInformation("로그아웃 완료");
  31. return Result.Success();
  32. }
  33. }