diff options
Diffstat (limited to 'Logics/CreateAdministratorSessionLogic.cs')
-rw-r--r-- | Logics/CreateAdministratorSessionLogic.cs | 18 |
1 files changed, 3 insertions, 15 deletions
diff --git a/Logics/CreateAdministratorSessionLogic.cs b/Logics/CreateAdministratorSessionLogic.cs index a7e1860..ce283c7 100644 --- a/Logics/CreateAdministratorSessionLogic.cs +++ b/Logics/CreateAdministratorSessionLogic.cs @@ -4,17 +4,10 @@ using BackendPIA.Models; using BackendPIA.Forms; namespace BackendPIA.Logics { - public class CreateAdministratorSessionLogic { - private readonly ITokenGenerator _token_generator; - private readonly UserManager<UserAccount> _manager; + public class CreateAdministratorSessionLogic : BaseUserAccountLogic { 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; + public CreateAdministratorSessionLogic(ITokenGenerator token_generator, UserManager<UserAccount> manager, UserAccountLoginForm form) : base(token_generator, manager) { _form = form; } @@ -27,12 +20,7 @@ namespace BackendPIA.Logics { 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); + SetAuthenticationToken(user); return true; } |