0
0

PermissionService.cs 10.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272
  1. using System;
  2. using System.Linq;
  3. using System.Threading.Tasks;
  4. using System.Collections.Generic;
  5. using AutoMapper;
  6. using Admin.Core.Repository.Admin;
  7. using Admin.Core.Model.Admin;
  8. using Admin.Core.Common.Output;
  9. using Admin.Core.Service.Admin.Permission.Input;
  10. using Admin.Core.Service.Admin.Permission.Output;
  11. using Admin.Core.Common.Cache;
  12. using Admin.Core.Common.Attributes;
  13. using Admin.Core.Common.Helpers;
  14. namespace Admin.Core.Service.Admin.Permission
  15. {
  16. public class PermissionService : BaseService,IPermissionService
  17. {
  18. private readonly IMapper _mapper;
  19. private readonly ICache _cache;
  20. private readonly IPermissionRepository _permissionRepository;
  21. private readonly IRoleRepository _roleRepository;
  22. private readonly IRolePermissionRepository _rolePermissionRepository;
  23. private readonly IUserRoleRepository _userRoleRepository;
  24. public PermissionService(
  25. IMapper mapper,
  26. ICache cache,
  27. IPermissionRepository permissionRepository,
  28. IRoleRepository roleRepository,
  29. IRolePermissionRepository rolePermissionRepository,
  30. IUserRoleRepository userRoleRepository
  31. )
  32. {
  33. _mapper = mapper;
  34. _cache = cache;
  35. _permissionRepository = permissionRepository;
  36. _roleRepository = roleRepository;
  37. _rolePermissionRepository = rolePermissionRepository;
  38. _userRoleRepository = userRoleRepository;
  39. }
  40. public async Task<IResponseOutput> GetAsync(long id)
  41. {
  42. var result = await _permissionRepository.GetAsync(id);
  43. return ResponseOutput.Ok(result);
  44. }
  45. public async Task<IResponseOutput> GetGroupAsync(long id)
  46. {
  47. var result = await _permissionRepository.GetAsync<PermissionGetGroupOutput>(id);
  48. return ResponseOutput.Ok(result);
  49. }
  50. public async Task<IResponseOutput> GetMenuAsync(long id)
  51. {
  52. var result = await _permissionRepository.GetAsync<PermissionGetMenuOutput>(id);
  53. return ResponseOutput.Ok(result);
  54. }
  55. public async Task<IResponseOutput> GetApiAsync(long id)
  56. {
  57. var result = await _permissionRepository.GetAsync<PermissionGetApiOutput>(id);
  58. return ResponseOutput.Ok(result);
  59. }
  60. public async Task<IResponseOutput> GetDotAsync(long id)
  61. {
  62. var result = await _permissionRepository.GetAsync<PermissionGetDotOutput>(id);
  63. return ResponseOutput.Ok(result);
  64. }
  65. public async Task<IResponseOutput> ListAsync(string key, DateTime? start, DateTime? end)
  66. {
  67. if (end.HasValue)
  68. {
  69. end = end.Value.AddDays(1);
  70. }
  71. var data = await _permissionRepository
  72. .WhereIf(key.NotNull(), a => a.Path.Contains(key) || a.Label.Contains(key))
  73. .WhereIf(start.HasValue && end.HasValue, a => a.CreatedTime.Value.BetweenEnd(start.Value, end.Value))
  74. .OrderBy(a => a.ParentId)
  75. .OrderBy(a => a.Sort)
  76. .ToListAsync(a => new PermissionListOutput { ApiPath = a.Api.Path });
  77. return ResponseOutput.Ok(data);
  78. }
  79. public async Task<IResponseOutput> AddGroupAsync(PermissionAddGroupInput input)
  80. {
  81. var entity = _mapper.Map<PermissionEntity>(input);
  82. var id = (await _permissionRepository.InsertAsync(entity)).Id;
  83. return ResponseOutput.Ok(id > 0);
  84. }
  85. public async Task<IResponseOutput> AddMenuAsync(PermissionAddMenuInput input)
  86. {
  87. var entity = _mapper.Map<PermissionEntity>(input);
  88. var id = (await _permissionRepository.InsertAsync(entity)).Id;
  89. return ResponseOutput.Ok(id > 0);
  90. }
  91. public async Task<IResponseOutput> AddApiAsync(PermissionAddApiInput input)
  92. {
  93. var entity = _mapper.Map<PermissionEntity>(input);
  94. var id = (await _permissionRepository.InsertAsync(entity)).Id;
  95. return ResponseOutput.Ok(id > 0);
  96. }
  97. public async Task<IResponseOutput> AddDotAsync(PermissionAddDotInput input)
  98. {
  99. var entity = _mapper.Map<PermissionEntity>(input);
  100. var id = (await _permissionRepository.InsertAsync(entity)).Id;
  101. return ResponseOutput.Ok(id > 0);
  102. }
  103. public async Task<IResponseOutput> UpdateGroupAsync(PermissionUpdateGroupInput input)
  104. {
  105. var result = false;
  106. if (input != null && input.Id > 0)
  107. {
  108. var entity = await _permissionRepository.GetAsync(input.Id);
  109. entity = _mapper.Map(input, entity);
  110. result = (await _permissionRepository.UpdateAsync(entity)) > 0;
  111. }
  112. return ResponseOutput.Result(result);
  113. }
  114. public async Task<IResponseOutput> UpdateMenuAsync(PermissionUpdateMenuInput input)
  115. {
  116. var result = false;
  117. if (input != null && input.Id > 0)
  118. {
  119. var entity = await _permissionRepository.GetAsync(input.Id);
  120. entity = _mapper.Map(input, entity);
  121. result = (await _permissionRepository.UpdateAsync(entity)) > 0;
  122. }
  123. return ResponseOutput.Result(result);
  124. }
  125. public async Task<IResponseOutput> UpdateApiAsync(PermissionUpdateApiInput input)
  126. {
  127. var result = false;
  128. if (input != null && input.Id > 0)
  129. {
  130. var entity = await _permissionRepository.GetAsync(input.Id);
  131. entity = _mapper.Map(input, entity);
  132. result = (await _permissionRepository.UpdateAsync(entity)) > 0;
  133. }
  134. return ResponseOutput.Result(result);
  135. }
  136. public async Task<IResponseOutput> UpdateDotAsync(PermissionUpdateDotInput input)
  137. {
  138. var result = false;
  139. if (input != null && input.Id > 0)
  140. {
  141. var entity = await _permissionRepository.GetAsync(input.Id);
  142. entity = _mapper.Map(input, entity);
  143. result = (await _permissionRepository.UpdateAsync(entity)) > 0;
  144. }
  145. return ResponseOutput.Result(result);
  146. }
  147. public async Task<IResponseOutput> DeleteAsync(long id)
  148. {
  149. var result = false;
  150. if (id > 0)
  151. {
  152. result = (await _permissionRepository.DeleteAsync(m => m.Id == id)) > 0;
  153. }
  154. return ResponseOutput.Result(result);
  155. }
  156. public async Task<IResponseOutput> SoftDeleteAsync(long id)
  157. {
  158. var result = await _permissionRepository.SoftDeleteAsync(id);
  159. return ResponseOutput.Result(result);
  160. }
  161. [Transaction]
  162. public async Task<IResponseOutput> AssignAsync(PermissionAssignInput input)
  163. {
  164. //分配权限的时候判断角色是否存在
  165. var exists = await _roleRepository.Select.DisableGlobalFilter("Tenant").WhereDynamic(input.RoleId).AnyAsync();
  166. if (!exists)
  167. {
  168. return ResponseOutput.NotOk("该角色不存在或已被删除!");
  169. }
  170. //查询角色权限
  171. var permissionIds = await _rolePermissionRepository.Select.Where(d => d.RoleId == input.RoleId).ToListAsync(m=>m.PermissionId);
  172. //批量删除权限
  173. var deleteIds = permissionIds.Where(d => !input.PermissionIds.Contains(d));
  174. if (deleteIds.Count() > 0)
  175. {
  176. await _rolePermissionRepository.DeleteAsync(m => m.RoleId == input.RoleId && deleteIds.Contains(m.PermissionId));
  177. }
  178. //批量插入权限
  179. var insertRolePermissions = new List<RolePermissionEntity>();
  180. var insertPermissionIds = input.PermissionIds.Where(d => !permissionIds.Contains(d));
  181. if (insertPermissionIds.Count() > 0)
  182. {
  183. foreach (var permissionId in insertPermissionIds)
  184. {
  185. insertRolePermissions.Add(new RolePermissionEntity()
  186. {
  187. RoleId = input.RoleId,
  188. PermissionId = permissionId,
  189. });
  190. }
  191. await _rolePermissionRepository.InsertAsync(insertRolePermissions);
  192. }
  193. //清除权限
  194. await _cache.DelByPatternAsync(CacheKey.UserPermissions);
  195. return ResponseOutput.Ok();
  196. }
  197. public async Task<IResponseOutput> GetPermissionList()
  198. {
  199. var permissions = await _permissionRepository.Select
  200. .Where(a =>
  201. _permissionRepository.Orm.Select<RolePermissionEntity>()
  202. .InnerJoin<UserRoleEntity>((b, c) => b.RoleId == c.RoleId && c.UserId == User.Id)
  203. .Where(b => b.PermissionId == a.Id)
  204. .Any()
  205. )
  206. .OrderBy(a => a.ParentId)
  207. .OrderBy(a => a.Sort)
  208. .ToListAsync(a => new { a.Id, a.ParentId, a.Label, a.Type });
  209. var apis = permissions
  210. .Where(a => new[] { PermissionType.Api, PermissionType.Dot }.Contains(a.Type))
  211. .Select(a => new { a.Id, a.ParentId, a.Label });
  212. var menus = permissions
  213. .Where(a => (new[] { PermissionType.Group, PermissionType.Menu }).Contains(a.Type))
  214. .Select(a => new
  215. {
  216. a.Id,
  217. a.ParentId,
  218. a.Label,
  219. Apis = apis.Where(b => b.ParentId == a.Id).Select(b => new { b.Id, b.Label })
  220. });
  221. return ResponseOutput.Ok(menus);
  222. }
  223. public async Task<IResponseOutput> GetRolePermissionList(long roleId = 0)
  224. {
  225. var permissionIds = await _rolePermissionRepository
  226. .Select.Where(d => d.RoleId == roleId)
  227. .ToListAsync(a=>a.PermissionId);
  228. return ResponseOutput.Ok(permissionIds);
  229. }
  230. }
  231. }