summaryrefslogtreecommitdiff
path: root/Logics/CreateAdministratorSessionLogic.cs
diff options
context:
space:
mode:
Diffstat (limited to 'Logics/CreateAdministratorSessionLogic.cs')
-rw-r--r--Logics/CreateAdministratorSessionLogic.cs18
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;
}