PermissionService.cs 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347
  1. using Admin.Core.Common.Attributes;
  2. using Admin.Core.Common.BaseModel;
  3. using Admin.Core.Common.Cache;
  4. using Admin.Core.Common.Configs;
  5. using Admin.Core.Common.Output;
  6. using Admin.Core.Model.Admin;
  7. using Admin.Core.Repository;
  8. using Admin.Core.Repository.Admin;
  9. using Admin.Core.Service.Admin.Permission.Input;
  10. using Admin.Core.Service.Admin.Permission.Output;
  11. using Microsoft.Extensions.DependencyInjection;
  12. using System;
  13. using System.Collections.Generic;
  14. using System.Linq;
  15. using System.Threading.Tasks;
  16. namespace Admin.Core.Service.Admin.Permission
  17. {
  18. public class PermissionService : BaseService, IPermissionService
  19. {
  20. private readonly AppConfig _appConfig;
  21. private readonly IPermissionRepository _permissionRepository;
  22. private readonly IRoleRepository _roleRepository;
  23. private readonly IRolePermissionRepository _rolePermissionRepository;
  24. private readonly IUserRepository _userRepository;
  25. private readonly IRepositoryBase<TenantPermissionEntity> _tenantPermissionRepository;
  26. private readonly IRepositoryBase<UserRoleEntity> _userRoleRepository;
  27. public PermissionService(
  28. AppConfig appConfig,
  29. IPermissionRepository permissionRepository,
  30. IRoleRepository roleRepository,
  31. IRolePermissionRepository rolePermissionRepository,
  32. IUserRepository userRepository,
  33. IRepositoryBase<TenantPermissionEntity> tenantPermissionRepository,
  34. IRepositoryBase<UserRoleEntity> userRoleRepository
  35. )
  36. {
  37. _appConfig = appConfig;
  38. _permissionRepository = permissionRepository;
  39. _roleRepository = roleRepository;
  40. _rolePermissionRepository = rolePermissionRepository;
  41. _userRepository = userRepository;
  42. _tenantPermissionRepository = tenantPermissionRepository;
  43. _userRoleRepository = userRoleRepository;
  44. }
  45. public async Task<IResponseOutput> GetAsync(long id)
  46. {
  47. var result = await _permissionRepository.GetAsync(id);
  48. return ResponseOutput.Ok(result);
  49. }
  50. public async Task<IResponseOutput> GetGroupAsync(long id)
  51. {
  52. var result = await _permissionRepository.GetAsync<PermissionGetGroupOutput>(id);
  53. return ResponseOutput.Ok(result);
  54. }
  55. public async Task<IResponseOutput> GetMenuAsync(long id)
  56. {
  57. var result = await _permissionRepository.GetAsync<PermissionGetMenuOutput>(id);
  58. return ResponseOutput.Ok(result);
  59. }
  60. public async Task<IResponseOutput> GetApiAsync(long id)
  61. {
  62. var result = await _permissionRepository.GetAsync<PermissionGetApiOutput>(id);
  63. return ResponseOutput.Ok(result);
  64. }
  65. public async Task<IResponseOutput> GetDotAsync(long id)
  66. {
  67. var result = await _permissionRepository.GetAsync<PermissionGetDotOutput>(id);
  68. return ResponseOutput.Ok(result);
  69. }
  70. public async Task<IResponseOutput> ListAsync(string key, DateTime? start, DateTime? end)
  71. {
  72. if (end.HasValue)
  73. {
  74. end = end.Value.AddDays(1);
  75. }
  76. var data = await _permissionRepository
  77. .WhereIf(key.NotNull(), a => a.Path.Contains(key) || a.Label.Contains(key))
  78. .WhereIf(start.HasValue && end.HasValue, a => a.CreatedTime.Value.BetweenEnd(start.Value, end.Value))
  79. .OrderBy(a => a.ParentId)
  80. .OrderBy(a => a.Sort)
  81. .ToListAsync(a => new PermissionListOutput { ApiPath = a.Api.Path });
  82. return ResponseOutput.Ok(data);
  83. }
  84. public async Task<IResponseOutput> AddGroupAsync(PermissionAddGroupInput input)
  85. {
  86. var entity = Mapper.Map<PermissionEntity>(input);
  87. var id = (await _permissionRepository.InsertAsync(entity)).Id;
  88. return ResponseOutput.Ok(id > 0);
  89. }
  90. public async Task<IResponseOutput> AddMenuAsync(PermissionAddMenuInput input)
  91. {
  92. var entity = Mapper.Map<PermissionEntity>(input);
  93. var id = (await _permissionRepository.InsertAsync(entity)).Id;
  94. return ResponseOutput.Ok(id > 0);
  95. }
  96. public async Task<IResponseOutput> AddApiAsync(PermissionAddApiInput input)
  97. {
  98. var entity = Mapper.Map<PermissionEntity>(input);
  99. var id = (await _permissionRepository.InsertAsync(entity)).Id;
  100. return ResponseOutput.Ok(id > 0);
  101. }
  102. public async Task<IResponseOutput> AddDotAsync(PermissionAddDotInput input)
  103. {
  104. var entity = Mapper.Map<PermissionEntity>(input);
  105. var id = (await _permissionRepository.InsertAsync(entity)).Id;
  106. return ResponseOutput.Ok(id > 0);
  107. }
  108. public async Task<IResponseOutput> UpdateGroupAsync(PermissionUpdateGroupInput input)
  109. {
  110. var result = false;
  111. if (input != null && input.Id > 0)
  112. {
  113. var entity = await _permissionRepository.GetAsync(input.Id);
  114. entity = Mapper.Map(input, entity);
  115. result = (await _permissionRepository.UpdateAsync(entity)) > 0;
  116. }
  117. return ResponseOutput.Result(result);
  118. }
  119. public async Task<IResponseOutput> UpdateMenuAsync(PermissionUpdateMenuInput input)
  120. {
  121. var result = false;
  122. if (input != null && input.Id > 0)
  123. {
  124. var entity = await _permissionRepository.GetAsync(input.Id);
  125. entity = Mapper.Map(input, entity);
  126. result = (await _permissionRepository.UpdateAsync(entity)) > 0;
  127. }
  128. return ResponseOutput.Result(result);
  129. }
  130. public async Task<IResponseOutput> UpdateApiAsync(PermissionUpdateApiInput input)
  131. {
  132. var result = false;
  133. if (input != null && input.Id > 0)
  134. {
  135. var entity = await _permissionRepository.GetAsync(input.Id);
  136. entity = Mapper.Map(input, entity);
  137. result = (await _permissionRepository.UpdateAsync(entity)) > 0;
  138. }
  139. return ResponseOutput.Result(result);
  140. }
  141. public async Task<IResponseOutput> UpdateDotAsync(PermissionUpdateDotInput input)
  142. {
  143. var result = false;
  144. if (input != null && input.Id > 0)
  145. {
  146. var entity = await _permissionRepository.GetAsync(input.Id);
  147. entity = Mapper.Map(input, entity);
  148. result = (await _permissionRepository.UpdateAsync(entity)) > 0;
  149. }
  150. return ResponseOutput.Result(result);
  151. }
  152. public async Task<IResponseOutput> DeleteAsync(long id)
  153. {
  154. var result = false;
  155. if (id > 0)
  156. {
  157. result = (await _permissionRepository.DeleteAsync(m => m.Id == id)) > 0;
  158. }
  159. return ResponseOutput.Result(result);
  160. }
  161. public async Task<IResponseOutput> SoftDeleteAsync(long id)
  162. {
  163. var result = await _permissionRepository.SoftDeleteAsync(id);
  164. return ResponseOutput.Result(result);
  165. }
  166. [Transaction]
  167. public async Task<IResponseOutput> AssignAsync(PermissionAssignInput input)
  168. {
  169. //分配权限的时候判断角色是否存在
  170. var exists = await _roleRepository.Select.DisableGlobalFilter("Tenant").WhereDynamic(input.RoleId).AnyAsync();
  171. if (!exists)
  172. {
  173. return ResponseOutput.NotOk("该角色不存在或已被删除!");
  174. }
  175. //查询角色权限
  176. var permissionIds = await _rolePermissionRepository.Select.Where(d => d.RoleId == input.RoleId).ToListAsync(m => m.PermissionId);
  177. //批量删除权限
  178. var deleteIds = permissionIds.Where(d => !input.PermissionIds.Contains(d));
  179. if (deleteIds.Any())
  180. {
  181. await _rolePermissionRepository.DeleteAsync(m => m.RoleId == input.RoleId && deleteIds.Contains(m.PermissionId));
  182. }
  183. //批量插入权限
  184. var insertRolePermissions = new List<RolePermissionEntity>();
  185. var insertPermissionIds = input.PermissionIds.Where(d => !permissionIds.Contains(d));
  186. //防止租户非法授权
  187. if (_appConfig.Tenant && User.TenantType == TenantType.Tenant)
  188. {
  189. var masterDb = ServiceProvider.GetRequiredService<IFreeSql>();
  190. var tenantPermissionIds = await masterDb.GetRepository<TenantPermissionEntity>().Select.Where(d => d.TenantId == User.TenantId).ToListAsync(m => m.PermissionId);
  191. insertPermissionIds = insertPermissionIds.Where(d => tenantPermissionIds.Contains(d));
  192. }
  193. if (insertPermissionIds.Any())
  194. {
  195. foreach (var permissionId in insertPermissionIds)
  196. {
  197. insertRolePermissions.Add(new RolePermissionEntity()
  198. {
  199. RoleId = input.RoleId,
  200. PermissionId = permissionId,
  201. });
  202. }
  203. await _rolePermissionRepository.InsertAsync(insertRolePermissions);
  204. }
  205. //清除角色下关联的用户权限缓存
  206. var userIds = await _userRoleRepository.Select.Where(a => a.RoleId == input.RoleId).ToListAsync(a => a.UserId);
  207. foreach (var userId in userIds)
  208. {
  209. await Cache.DelAsync(string.Format(CacheKey.UserPermissions, userId));
  210. }
  211. return ResponseOutput.Ok();
  212. }
  213. [Transaction]
  214. public async Task<IResponseOutput> SaveTenantPermissionsAsync(PermissionSaveTenantPermissionsInput input)
  215. {
  216. //获得租户db
  217. var ib = ServiceProvider.GetRequiredService<IdleBus<IFreeSql>>();
  218. var tenantDb = ib.GetTenantFreeSql(ServiceProvider, input.TenantId);
  219. //查询租户权限
  220. var permissionIds = await _tenantPermissionRepository.Select.Where(d => d.TenantId == input.TenantId).ToListAsync(m => m.PermissionId);
  221. //批量删除租户权限
  222. var deleteIds = permissionIds.Where(d => !input.PermissionIds.Contains(d));
  223. if (deleteIds.Any())
  224. {
  225. await _tenantPermissionRepository.DeleteAsync(m => m.TenantId == input.TenantId && deleteIds.Contains(m.PermissionId));
  226. //删除租户下关联的角色权限
  227. await tenantDb.GetRepository<RolePermissionEntity>().DeleteAsync(a => deleteIds.Contains(a.PermissionId));
  228. }
  229. //批量插入租户权限
  230. var tenatPermissions = new List<TenantPermissionEntity>();
  231. var insertPermissionIds = input.PermissionIds.Where(d => !permissionIds.Contains(d));
  232. if (insertPermissionIds.Any())
  233. {
  234. foreach (var permissionId in insertPermissionIds)
  235. {
  236. tenatPermissions.Add(new TenantPermissionEntity()
  237. {
  238. TenantId = input.TenantId,
  239. PermissionId = permissionId,
  240. });
  241. }
  242. await _tenantPermissionRepository.InsertAsync(tenatPermissions);
  243. }
  244. //清除租户下所有用户权限缓存
  245. var userIds = await tenantDb.GetRepository<UserEntity>().Select.Where(a => a.TenantId == input.TenantId).ToListAsync(a => a.Id);
  246. if(userIds.Any())
  247. {
  248. foreach (var userId in userIds)
  249. {
  250. await Cache.DelAsync(string.Format(CacheKey.UserPermissions, userId));
  251. }
  252. }
  253. return ResponseOutput.Ok();
  254. }
  255. public async Task<IResponseOutput> GetPermissionList()
  256. {
  257. var permissions = await _permissionRepository.Select
  258. .WhereIf(_appConfig.Tenant && User.TenantType == TenantType.Tenant, a =>
  259. _tenantPermissionRepository
  260. .Where(b => b.PermissionId == a.Id && b.TenantId == User.TenantId)
  261. .Any()
  262. )
  263. .OrderBy(a => a.ParentId)
  264. .OrderBy(a => a.Sort)
  265. .ToListAsync(a => new { a.Id, a.ParentId, a.Label, a.Type });
  266. var apis = permissions
  267. .Where(a => new[] { PermissionType.Api, PermissionType.Dot }.Contains(a.Type))
  268. .Select(a => new { a.Id, a.ParentId, a.Label });
  269. var menus = permissions
  270. .Where(a => (new[] { PermissionType.Group, PermissionType.Menu }).Contains(a.Type))
  271. .Select(a => new
  272. {
  273. a.Id,
  274. a.ParentId,
  275. a.Label,
  276. Apis = apis.Where(b => b.ParentId == a.Id).Select(b => new { b.Id, b.Label })
  277. });
  278. return ResponseOutput.Ok(menus);
  279. }
  280. public async Task<IResponseOutput> GetRolePermissionList(long roleId = 0)
  281. {
  282. var permissionIds = await _rolePermissionRepository
  283. .Select.Where(d => d.RoleId == roleId)
  284. .ToListAsync(a => a.PermissionId);
  285. return ResponseOutput.Ok(permissionIds);
  286. }
  287. public async Task<IResponseOutput> GetTenantPermissionList(long tenantId)
  288. {
  289. var permissionIds = await _tenantPermissionRepository
  290. .Select.Where(d => d.TenantId == tenantId)
  291. .ToListAsync(a => a.PermissionId);
  292. return ResponseOutput.Ok(permissionIds);
  293. }
  294. }
  295. }