diff options
author | HombreLaser <sebastian-440@live.com> | 2022-11-18 16:32:38 -0600 |
---|---|---|
committer | HombreLaser <sebastian-440@live.com> | 2022-11-18 16:32:38 -0600 |
commit | a640608ab8ff895be3125ebf75a4d3d19139f5c3 (patch) | |
tree | 5634b61500b4925bb07f918ec5780a93186bb89e /Logics | |
parent | 22b5afd25bc29f920f46456c0a6acf6847a9af5e (diff) |
Añadido login de administradores
Diffstat (limited to 'Logics')
-rw-r--r-- | Logics/CreateAdministratorSessionLogic.cs | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/Logics/CreateAdministratorSessionLogic.cs b/Logics/CreateAdministratorSessionLogic.cs new file mode 100644 index 0000000..a7e1860 --- /dev/null +++ b/Logics/CreateAdministratorSessionLogic.cs @@ -0,0 +1,43 @@ +using Microsoft.AspNetCore.Identity; +using BackendPIA.Services; +using BackendPIA.Models; +using BackendPIA.Forms; + +namespace BackendPIA.Logics { + public class CreateAdministratorSessionLogic { + private readonly ITokenGenerator _token_generator; + private readonly UserManager<UserAccount> _manager; + private readonly UserAccountLoginForm _form; + private AuthenticationToken _token; + + public AuthenticationToken Token { get { return _token; } } + + public CreateAdministratorSessionLogic(ITokenGenerator token_generator, UserManager<UserAccount> manager, UserAccountLoginForm form) { + _token_generator = token_generator; + _manager = manager; + _form = form; + } + + public async Task<bool> Call() { + var user = await _manager.FindByEmailAsync(_form.Email); + + if(user == null) + return false; + + var result = await _manager.CheckPasswordAsync(user, _form.Password); + + if(result) { + _token = new AuthenticationToken { Token = _token_generator.Generate(user, "administrator"), + RefreshToken = _token_generator.GenerateRefreshToken() }; + // We overwrite or set the value of the session token in the database: all other previous logins are invalid. + user.SessionToken = _token.RefreshToken; + user.SessionTokenExpiryTime = DateTime.UtcNow.AddHours(3); + await _manager.UpdateAsync(user); + + return true; + } + + return false; + } + } +}
\ No newline at end of file |