summaryrefslogtreecommitdiff
path: root/Logics
diff options
context:
space:
mode:
Diffstat (limited to 'Logics')
-rw-r--r--Logics/BaseUserAccountLogic.cs31
-rw-r--r--Logics/CreateAdministratorLogic.cs37
-rw-r--r--Logics/CreateAdministratorSessionLogic.cs18
3 files changed, 71 insertions, 15 deletions
diff --git a/Logics/BaseUserAccountLogic.cs b/Logics/BaseUserAccountLogic.cs
new file mode 100644
index 0000000..1686bb6
--- /dev/null
+++ b/Logics/BaseUserAccountLogic.cs
@@ -0,0 +1,31 @@
+using Microsoft.AspNetCore.Identity;
+using BackendPIA.Services;
+using BackendPIA.Forms;
+using BackendPIA.Models;
+
+namespace BackendPIA.Logics {
+ public abstract class BaseUserAccountLogic {
+ protected readonly ITokenGenerator _token_generator;
+ protected readonly UserManager<UserAccount> _manager;
+ protected AuthenticationToken? _token;
+ public AuthenticationToken? Token { get { return _token; } }
+
+ public BaseUserAccountLogic(ITokenGenerator token_generator, UserManager<UserAccount> manager) {
+ _manager = manager;
+ _token_generator = token_generator;
+ }
+
+ protected async Task SetAuthenticationToken(UserAccount user) {
+ _token = new AuthenticationToken { Token = _token_generator.Generate(user, "administrator"),
+ RefreshToken = _token_generator.GenerateRefreshToken() };
+ await SetUserRefreshToken(user);
+ }
+
+ // We overwrite or set the value of the session token in the database: all other previous logins are invalid.
+ private async Task SetUserRefreshToken(UserAccount user) {
+ user.SessionToken = _token.RefreshToken;
+ user.SessionTokenExpiryTime = DateTime.UtcNow.AddHours(3);
+ await _manager.UpdateAsync(user);
+ }
+ }
+} \ No newline at end of file
diff --git a/Logics/CreateAdministratorLogic.cs b/Logics/CreateAdministratorLogic.cs
new file mode 100644
index 0000000..9f8e573
--- /dev/null
+++ b/Logics/CreateAdministratorLogic.cs
@@ -0,0 +1,37 @@
+using AutoMapper;
+using Microsoft.AspNetCore.Identity;
+using BackendPIA.Services;
+using BackendPIA.Models;
+using BackendPIA.Forms;
+
+namespace BackendPIA.Logics{
+ public class CreateAdministratorLogic : BaseUserAccountLogic {
+ private readonly UserAccountForm _form;
+ private readonly IMapper _mapper;
+ private readonly IUserAccountService _user_account_service;
+ private IEnumerable<IdentityError> _errors;
+ public IEnumerable<IdentityError> Errors { get => _errors; }
+
+ public CreateAdministratorLogic(ITokenGenerator token_generator, UserManager<UserAccount> manager, UserAccountForm form,
+ IMapper mapper, IUserAccountService service) : base(token_generator, manager)
+ {
+ _form = form;
+ _mapper = mapper;
+ _user_account_service = service;
+ }
+
+ public async Task<bool> Call() {
+ UserAccount user = _mapper.Map<UserAccount>(_form);
+ var result = await _user_account_service.CreateUserAccount(user, _form.Password, "Administrator");
+
+ if(result.Succeeded) {
+ SetAuthenticationToken(user);
+
+ return true;
+ }
+
+ _errors = result.Errors;
+ return false;
+ }
+ }
+} \ No newline at end of file
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;
}