Handler.cs 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. using Application.Abstractions.Data;
  2. using Application.Abstractions.Messaging;
  3. using SharedKernel.Results;
  4. using Microsoft.EntityFrameworkCore;
  5. namespace Application.Features.Api.MyPage.ChangePassword;
  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.CurrentPassword))
  11. {
  12. return Result.Failure(Error.Problem("MyPage.CurrentPasswordRequired", "현재 비밀번호는 필수입니다."));
  13. }
  14. if (string.IsNullOrWhiteSpace(request.NewPassword))
  15. {
  16. return Result.Failure(Error.Problem("MyPage.NewPasswordRequired", "새 비밀번호는 필수입니다."));
  17. }
  18. if (request.NewPassword.Length < 6)
  19. {
  20. return Result.Failure(Error.Problem("MyPage.PasswordTooShort", "비밀번호는 6자 이상이어야 합니다."));
  21. }
  22. if (request.NewPassword != request.ConfirmPassword)
  23. {
  24. return Result.Failure(Error.Problem("MyPage.PasswordMismatch", "새 비밀번호가 일치하지 않습니다."));
  25. }
  26. var member = await db.Member.FirstOrDefaultAsync(m => m.ID == request.MemberID, ct);
  27. if (member is null)
  28. {
  29. return Result.Failure(Error.NotFound("MyPage.MemberNotFound", "회원 정보를 찾을 수 없습니다."));
  30. }
  31. if (!member.VerifyPassword(request.CurrentPassword))
  32. {
  33. return Result.Failure(Error.Problem("MyPage.InvalidPassword", "현재 비밀번호가 올바르지 않습니다."));
  34. }
  35. member.SetPassword(request.NewPassword);
  36. await db.SaveChangesAsync(ct);
  37. return Result.Success();
  38. }
  39. }