diff options
| author | Danail Dimitrov <danaildimitrov321@gmail.com> | 2020-12-15 20:39:59 +0200 |
|---|---|---|
| committer | Danail Dimitrov <danaildimitrov321@gmail.com> | 2020-12-15 20:39:59 +0200 |
| commit | 98ae2dde03781166518fb586b81753ac2f923831 (patch) | |
| tree | 35fcb6905fa19acb73af9982223648f47305a83d /src/DevHive.Services | |
| parent | b6855296340e4b70ee7a83d3118780eb23e46c83 (diff) | |
| parent | b4f102b15879fd2a8415fd42373c990e17a86baf (diff) | |
| download | DevHive-98ae2dde03781166518fb586b81753ac2f923831.tar DevHive-98ae2dde03781166518fb586b81753ac2f923831.tar.gz DevHive-98ae2dde03781166518fb586b81753ac2f923831.zip | |
Merge branch 'dev' of github.com:Team-Kaleidoscope/DevHive into dev
Diffstat (limited to 'src/DevHive.Services')
| -rw-r--r-- | src/DevHive.Services/Services/RoleService.cs | 53 |
1 files changed, 42 insertions, 11 deletions
diff --git a/src/DevHive.Services/Services/RoleService.cs b/src/DevHive.Services/Services/RoleService.cs index 9077a47..b3e734d 100644 --- a/src/DevHive.Services/Services/RoleService.cs +++ b/src/DevHive.Services/Services/RoleService.cs @@ -1,5 +1,7 @@ using System; using System.Threading.Tasks; +using AutoMapper; +using DevHive.Data.Models; using DevHive.Data.Repositories; using DevHive.Services.Models.Identity.Role; using Microsoft.AspNetCore.Mvc; @@ -8,31 +10,60 @@ namespace DevHive.Services.Services { public class RoleService { - private readonly DevHiveContext _context; + private readonly RoleRepository _roleRepository; + private readonly IMapper _roleMapper; - public RoleService(DevHiveContext context) + public RoleService(DevHiveContext context, IMapper mapper) { - this._context = context; + this._roleRepository = new RoleRepository(context); + this._roleMapper = mapper; } - public Task<IActionResult> CreateRole(RoleServiceModel roleServiceModel) + public async Task<IActionResult> CreateRole(RoleServiceModel roleServiceModel) { - throw new NotImplementedException(); + if (!await this._roleRepository.DoesNameExist(roleServiceModel.Name)) + return new BadRequestObjectResult("Invalid role name!"); + + Role role = this._roleMapper.Map<Role>(roleServiceModel); + + await this._roleRepository.AddAsync(role); + + return new CreatedResult("CreateRole", role); } - public Task<IActionResult> GetRoleById(Guid id) + public async Task<IActionResult> GetRoleById(Guid id) { - throw new NotImplementedException(); + Role role = await this._roleRepository.GetByIdAsync(id); + + if (role == null) + return new NotFoundObjectResult("Role does not exist!"); + + return new ObjectResult(role); } - public Task<IActionResult> UpdateRole(RoleServiceModel roleServiceModel) + public async Task<IActionResult> UpdateRole(RoleServiceModel roleServiceModel) { - throw new NotImplementedException(); + if (!await this._roleRepository.DoesRoleExist(roleServiceModel.Id)) + return new NotFoundObjectResult("Role does not exist!"); + + if (!await this._roleRepository.DoesNameExist(roleServiceModel.Name)) + return new BadRequestObjectResult("Role name already exists!"); + + Role role = this._roleMapper.Map<Role>(roleServiceModel); + await this._roleRepository.EditAsync(role); + + return new AcceptedResult("UpdateRole", role); } - public Task<IActionResult> DeleteRole(Guid id) + public async Task<IActionResult> DeleteRole(Guid id) { - throw new NotImplementedException(); + if (!await this._roleRepository.DoesRoleExist(id)) + return new NotFoundObjectResult("Role does not exist!"); + + Role role = await this._roleRepository.GetByIdAsync(id); + await this._roleRepository.DeleteAsync(role); + + return new OkResult(); } } } |
