using System.Threading.Tasks; using Admin.Core.Common.Input; using Admin.Core.Common.Output; using Admin.Core.Model.Admin; using Admin.Core.Repository.Admin; using Admin.Core.Service.Admin.Role.Input; using Admin.Core.Service.Admin.Role.Output; using System.Linq; namespace Admin.Core.Service.Admin.Role { public class RoleService : BaseService, IRoleService { private readonly IRoleRepository _roleRepository; private readonly IRolePermissionRepository _rolePermissionRepository; public RoleService( IRoleRepository roleRepository, IRolePermissionRepository rolePermissionRepository ) { _roleRepository = roleRepository; _rolePermissionRepository = rolePermissionRepository; } public async Task GetAsync(long id) { var result = await _roleRepository.GetAsync(id); return ResponseOutput.Ok(result); } public async Task PageAsync(PageInput input) { var key = input.Filter?.Name; var list = await _roleRepository.Select .WhereIf(key.NotNull(), a => a.Name.Contains(key)) .Count(out var total) .OrderByDescending(true, c => c.Id) .Page(input.CurrentPage, input.PageSize) .ToListAsync(); var data = new PageOutput() { List = list, Total = total }; return ResponseOutput.Ok(data); } public async Task AddAsync(RoleAddInput input) { var entity = Mapper.Map(input); var id = (await _roleRepository.InsertAsync(entity)).Id; return ResponseOutput.Result(id > 0); } public async Task UpdateAsync(RoleUpdateInput input) { if (!(input?.Id > 0)) { return ResponseOutput.NotOk(); } var entity = await _roleRepository.GetAsync(input.Id); if (!(entity?.Id > 0)) { return ResponseOutput.NotOk("½اة«²»´وشع£،"); } Mapper.Map(input, entity); await _roleRepository.UpdateAsync(entity); return ResponseOutput.Ok(); } public async Task DeleteAsync(long id) { var result = false; if (id > 0) { result = (await _roleRepository.DeleteAsync(m => m.Id == id)) > 0; } return ResponseOutput.Result(result); } public async Task SoftDeleteAsync(long id) { var result = await _roleRepository.SoftDeleteAsync(id); await _rolePermissionRepository.DeleteAsync(a => a.RoleId == id); return ResponseOutput.Result(result); } public async Task BatchSoftDeleteAsync(long[] ids) { var result = await _roleRepository.SoftDeleteAsync(ids); await _rolePermissionRepository.DeleteAsync(a => ids.Contains(a.RoleId)); return ResponseOutput.Result(result); } } }