| | 1 | | using System.IdentityModel.Tokens.Jwt; |
| | 2 | | using Syki.Back.Features.Cross.CreateUser; |
| | 3 | | using Syki.Back.Features.Cross.GenerateJWT; |
| | 4 | |
|
| | 5 | | namespace Syki.Back.Features.Cross.Login; |
| | 6 | |
|
| 956 | 7 | | public class LoginService(GenerateJWTService service, SignInManager<SykiUser> signInManager) : ICrossService |
| | 8 | | { |
| | 9 | | public async Task<OneOf<LoginOut, SykiError>> Login(LoginIn data) |
| | 10 | | { |
| 956 | 11 | | var result = await signInManager.PasswordSignInAsync( |
| 956 | 12 | | userName: data.Email, |
| 956 | 13 | | password: data.Password, |
| 956 | 14 | | isPersistent: false, |
| 956 | 15 | | lockoutOnFailure: false |
| 956 | 16 | | ); |
| | 17 | |
|
| 956 | 18 | | if (!result.Succeeded && !result.RequiresTwoFactor) |
| 8 | 19 | | return new LoginWrongEmailOrPassword(); |
| | 20 | |
|
| 948 | 21 | | if (result.RequiresTwoFactor) |
| 6 | 22 | | return new LoginRequiresTwoFactor(); |
| | 23 | |
|
| 942 | 24 | | var jwt = await service.Generate(data.Email); |
| 942 | 25 | | var claims = new JwtSecurityToken(jwt).Claims.ToList(); |
| | 26 | |
|
| 942 | 27 | | return new LoginOut |
| 942 | 28 | | { |
| 942 | 29 | | AccessToken = jwt, |
| 3768 | 30 | | Name = claims.First(x => x.Type == "name").Value, |
| 4710 | 31 | | Email = claims.First(x => x.Type == "email").Value, |
| 1884 | 32 | | Id = Guid.Parse(claims.First(x => x.Type == "sub").Value), |
| 2826 | 33 | | Role = Enum.Parse<UserRole>(claims.First(x => x.Type == "role").Value), |
| 942 | 34 | | }; |
| 956 | 35 | | } |
| | 36 | | } |