diff options
author | HombreLaser <sebastian-440@live.com> | 2022-11-20 16:25:07 -0600 |
---|---|---|
committer | HombreLaser <sebastian-440@live.com> | 2022-11-20 16:25:07 -0600 |
commit | 0eb1eacf11f8c713478c08633f92d7579da91992 (patch) | |
tree | 5f3704778ac581493369b34ace33fcfb29caca4f /Logics | |
parent | 61e9edfd4607b5eab5c291f49cdc3b2c7cb9d654 (diff) |
Añadido controlador de administradores
Diffstat (limited to 'Logics')
-rw-r--r-- | Logics/BaseUserAccountLogic.cs | 31 | ||||
-rw-r--r-- | Logics/CreateAdministratorLogic.cs | 37 | ||||
-rw-r--r-- | Logics/CreateAdministratorSessionLogic.cs | 18 |
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; } |