Added models for presentation layer with data annotations
This commit is contained in:
		| @@ -0,0 +1,6 @@ | ||||
| using ApplicationLayer.Services.GeneralExceptions; | ||||
| using Domains.Users; | ||||
|  | ||||
| namespace ApplicationLayer.Services.Users.Exceptions; | ||||
|  | ||||
| public class WrongRoleException(Guid userId) : EntityNotFoundByIdException<User>(userId); | ||||
| @@ -10,13 +10,13 @@ public interface IUsersService | ||||
|     /// <param name="cancellationToken">Cancellation token</param> | ||||
|     Task<List<User>> GetAuthoritiesAccountsAsync(CancellationToken cancellationToken); | ||||
|  | ||||
|     /// Changes authentication data for an account | ||||
|     /// Changes authentication data for an authority account | ||||
|     /// <param name="request"> Request object with identifier of user and new authentication data</param> | ||||
|     /// <param name="cancellationToken">Cancellation token</param> | ||||
|     Task ChangeAccountAuthDataAsync(ChangeUserAuthDataRequest request, CancellationToken cancellationToken); | ||||
|     Task ChangeAuthorityAuthDataAsync(ChangeUserAuthDataRequest request, CancellationToken cancellationToken); | ||||
|  | ||||
|     /// Removes user account | ||||
|     /// Removes account of authority | ||||
|     /// <param name="userId">Identifier of account</param> | ||||
|     /// <param name="cancellationToken">Cancellation token</param> | ||||
|     Task RemoveUserAccount(Guid userId, CancellationToken cancellationToken); | ||||
| } | ||||
|     Task RemoveAuthorityAccount(Guid userId, CancellationToken cancellationToken); | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,11 @@ | ||||
| using ApplicationLayer.Services.AuthServices.Common; | ||||
| using System.ComponentModel.DataAnnotations; | ||||
| using ApplicationLayer.Services.AuthServices.Common; | ||||
|  | ||||
| namespace ApplicationLayer.Services.Users.Requests; | ||||
|  | ||||
| public record ChangeUserAuthDataRequest(Guid UserId, AuthData NewAuthData); | ||||
| public class ChangeUserAuthDataRequest(Guid userId, AuthData newAuthData) | ||||
| { | ||||
|     [Required] public Guid UserId { get; set; } = userId; | ||||
|  | ||||
|     [Required] public AuthData NewAuthData { get; set; } = newAuthData; | ||||
| } | ||||
|   | ||||
| @@ -1,5 +1,7 @@ | ||||
| using ApplicationLayer.InfrastructureServicesInterfaces; | ||||
| using ApplicationLayer.Services.AuthServices.Common; | ||||
| using ApplicationLayer.Services.AuthServices.NeededServices; | ||||
| using ApplicationLayer.Services.Users.Exceptions; | ||||
| using ApplicationLayer.Services.Users.Requests; | ||||
| using Domains.Users; | ||||
|  | ||||
| @@ -7,27 +9,59 @@ namespace ApplicationLayer.Services.Users; | ||||
|  | ||||
| public class UsersService(IUsersRepository users, IUnitOfWork unitOfWork) : IUsersService | ||||
| { | ||||
|     async Task<List<User>> IUsersService.GetAuthoritiesAccountsAsync(CancellationToken cancellationToken) | ||||
|     async Task<List<User>> IUsersService.GetAuthoritiesAccountsAsync(CancellationToken cancellationToken) => | ||||
|         await users.GetAllOfRoleAsync(Role.ApprovingAuthority, cancellationToken); | ||||
|  | ||||
|     async Task IUsersService.ChangeAuthorityAuthDataAsync(ChangeUserAuthDataRequest request, CancellationToken cancellationToken) | ||||
|     { | ||||
|             return await users.GetAllOfRoleAsync(Role.ApprovingAuthority, cancellationToken); | ||||
|         } | ||||
|         var user = await users.GetByIdAsync(request.UserId, cancellationToken); | ||||
|  | ||||
|     async Task IUsersService.ChangeAccountAuthDataAsync(ChangeUserAuthDataRequest request, CancellationToken cancellationToken) | ||||
|         ValidateRole(user, Role.ApprovingAuthority); | ||||
|  | ||||
|         await ChangeAccountAuthDataAsync(user, request.NewAuthData, cancellationToken); | ||||
|     } | ||||
|  | ||||
|     async Task IUsersService.RemoveAuthorityAccount(Guid userId, CancellationToken cancellationToken) | ||||
|     { | ||||
|             var user = await users.GetByIdAsync(request.UserId, cancellationToken); | ||||
|         var user = await users.GetByIdAsync(userId, cancellationToken); | ||||
|  | ||||
|             user.Email = request.NewAuthData.Email; | ||||
|             user.Password = request.NewAuthData.Password; | ||||
|             await users.UpdateAsync(user, cancellationToken); | ||||
|         ValidateRole(user, Role.ApprovingAuthority); | ||||
|  | ||||
|             await unitOfWork.SaveAsync(cancellationToken); | ||||
|         } | ||||
|         await RemoveUserAccount(user, cancellationToken); | ||||
|     } | ||||
|  | ||||
|     async Task IUsersService.RemoveUserAccount(Guid userId, CancellationToken cancellationToken) | ||||
|     /// Updates user account auth data | ||||
|     /// <param name="user">User to remove</param> | ||||
|     /// <param name="authData">New auth data</param> | ||||
|     /// <param name="cancellationToken">Cancellation token</param> | ||||
|     private async Task ChangeAccountAuthDataAsync(User user, AuthData authData, CancellationToken cancellationToken) | ||||
|     { | ||||
|             var user = await users.GetByIdAsync(userId, cancellationToken); | ||||
|             users.Remove(user); | ||||
|         user.Email = authData.Email; | ||||
|         user.Password = authData.Password; | ||||
|         await users.UpdateAsync(user, cancellationToken); | ||||
|  | ||||
|             await unitOfWork.SaveAsync(cancellationToken); | ||||
|         await unitOfWork.SaveAsync(cancellationToken); | ||||
|     } | ||||
|  | ||||
|     /// Removes user account from DB | ||||
|     /// <param name="user">User to remove</param> | ||||
|     /// <param name="cancellationToken">Cancellation token</param> | ||||
|     private async Task RemoveUserAccount(User user, CancellationToken cancellationToken) | ||||
|     { | ||||
|         users.Remove(user); | ||||
|  | ||||
|         await unitOfWork.SaveAsync(cancellationToken); | ||||
|     } | ||||
|  | ||||
|     /// Checks if role of user equals expected | ||||
|     /// <param name="user">User to check</param> | ||||
|     /// <param name="expectedRole">Expected role</param> | ||||
|     /// <exception cref="WrongRoleException">Role is not expected</exception> | ||||
|     private static void ValidateRole(User user, Role expectedRole) | ||||
|     { | ||||
|         if (user.Role != expectedRole) | ||||
|         { | ||||
|             throw new WrongRoleException(user.Id); | ||||
|         } | ||||
| } | ||||
|     } | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user