Files
amrez-nova-eop-services-api/AMREZ.EOP.Application/UseCases/Authentications/LoginUseCase.cs
Thanakarn Klangkasame ad0d9e41ba Fix Access/Refres Token
2025-10-05 17:24:30 +07:00

74 lines
2.6 KiB
C#

using System.Data;
using AMREZ.EOP.Abstractions.Applications.Tenancy;
using AMREZ.EOP.Abstractions.Applications.UseCases.Authentications;
using AMREZ.EOP.Abstractions.Infrastructures.Common;
using AMREZ.EOP.Abstractions.Infrastructures.Repositories;
using AMREZ.EOP.Abstractions.Security;
using AMREZ.EOP.Contracts.DTOs.Authentications.Login;
using Microsoft.AspNetCore.Http;
namespace AMREZ.EOP.Application.UseCases.Authentications
{
public sealed class LoginUseCase : ILoginUseCase
{
private readonly ITenantResolver _tenantResolver;
private readonly IUserRepository _users;
private readonly ITenantRepository _tenants;
private readonly IPasswordHasher _hasher;
private readonly IHttpContextAccessor _http;
private readonly IUnitOfWork _uow;
public LoginUseCase(
ITenantResolver tenantResolver,
IUserRepository users,
ITenantRepository tenants,
IPasswordHasher hasher,
IHttpContextAccessor http,
IUnitOfWork uow)
{
_tenantResolver = tenantResolver;
_users = users;
_tenants = tenants;
_hasher = hasher;
_http = http;
_uow = uow;
}
public async Task<LoginResponse?> ExecuteAsync(LoginRequest request, CancellationToken ct = default)
{
var http = _http.HttpContext ?? throw new InvalidOperationException("No HttpContext");
var platform = _tenantResolver.Resolve(http, "@platform");
if (platform is null) return null;
var email = request.Email.Trim().ToLowerInvariant();
await _uow.BeginAsync(platform, IsolationLevel.ReadCommitted, ct);
try
{
var user = await _users.FindActiveByEmailAsync(email, ct);
if (user is null || !_hasher.Verify(request.Password, user.PasswordHash))
{
await _uow.RollbackAsync(ct);
return null;
}
var tenantKey = await _tenants.GetTenantKeyByTenantIdAsync(user.TenantId, ct);
if (string.IsNullOrWhiteSpace(tenantKey))
{
await _uow.RollbackAsync(ct);
return null;
}
await _uow.CommitAsync(ct);
return new LoginResponse(user.Id, user.TenantId, email, tenantKey);
}
catch
{
await _uow.RollbackAsync(ct);
throw;
}
}
}
}