Handler.cs 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. using Application.Abstractions.Data;
  2. using Application.Abstractions.Messaging;
  3. using SharedKernel.Results;
  4. using Microsoft.EntityFrameworkCore;
  5. namespace Application.Features.Api.MyPage.Withdraw;
  6. internal sealed class Handler(IAppDbContext db) : ICommandHandler<Command, Result>
  7. {
  8. public async Task<Result> Handle(Command request, CancellationToken ct)
  9. {
  10. if (string.IsNullOrWhiteSpace(request.Password))
  11. {
  12. return Result.Failure(Error.Problem("MyPage.PasswordRequired", "비밀번호는 필수입니다."));
  13. }
  14. var member = await db.Member.FirstOrDefaultAsync(m => m.ID == request.MemberID, ct);
  15. if (member is null)
  16. {
  17. return Result.Failure(Error.NotFound("MyPage.MemberNotFound", "회원 정보를 찾을 수 없습니다."));
  18. }
  19. if (!member.VerifyPassword(request.Password))
  20. {
  21. return Result.Failure(Error.Problem("MyPage.InvalidPassword", "비밀번호가 올바르지 않습니다."));
  22. }
  23. // RefreshToken 무효화
  24. var refreshTokens = await db.RefreshToken.Where(t => t.MemberID == request.MemberID && !t.IsRevoked).ToListAsync(ct);
  25. foreach (var token in refreshTokens)
  26. {
  27. token.Revoke();
  28. }
  29. member.Withdraw();
  30. await db.SaveChangesAsync(ct);
  31. return Result.Success();
  32. }
  33. }