mirror of
https://github.com/aaronpo97/the-biergarten-app.git
synced 2026-04-05 18:09:04 +00:00
42 lines
1.3 KiB
C#
42 lines
1.3 KiB
C#
using Domain.Entities;
|
|
using Domain.Exceptions;
|
|
using Infrastructure.PasswordHashing;
|
|
using Infrastructure.Repository.Auth;
|
|
|
|
namespace Service.Auth;
|
|
|
|
|
|
public class LoginService(
|
|
IAuthRepository authRepo,
|
|
IPasswordInfrastructure passwordInfrastructure,
|
|
ITokenService tokenService
|
|
) : ILoginService
|
|
{
|
|
public async Task<LoginServiceReturn> LoginAsync(
|
|
string username,
|
|
string password
|
|
)
|
|
{
|
|
// Attempt lookup by username
|
|
// the user was not found
|
|
var user =
|
|
await authRepo.GetUserByUsernameAsync(username)
|
|
?? throw new UnauthorizedException("Invalid username or password.");
|
|
|
|
// @todo handle expired passwords
|
|
var activeCred =
|
|
await authRepo.GetActiveCredentialByUserAccountIdAsync(
|
|
user.UserAccountId
|
|
)
|
|
?? throw new UnauthorizedException("Invalid username or password.");
|
|
|
|
if (!passwordInfrastructure.Verify(password, activeCred.Hash))
|
|
throw new UnauthorizedException("Invalid username or password.");
|
|
|
|
string accessToken = tokenService.GenerateAccessToken(user);
|
|
string refreshToken = tokenService.GenerateRefreshToken(user);
|
|
|
|
return new LoginServiceReturn(user, refreshToken, accessToken);
|
|
}
|
|
}
|