TenantService.cs 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290
  1. using System.Linq;
  2. using System.Threading.Tasks;
  3. using Microsoft.AspNetCore.Mvc;
  4. using ZhonTai.Admin.Core.Attributes;
  5. using ZhonTai.Admin.Core.Repositories;
  6. using ZhonTai.Common.Helpers;
  7. using ZhonTai.Admin.Core.Dto;
  8. using ZhonTai.Admin.Domain.Role;
  9. using ZhonTai.Admin.Domain.RolePermission;
  10. using ZhonTai.Admin.Domain.Tenant;
  11. using ZhonTai.Admin.Domain.User;
  12. using ZhonTai.Admin.Domain.UserRole;
  13. using ZhonTai.Admin.Services.Tenant.Dto;
  14. using ZhonTai.Admin.Domain.Tenant.Dto;
  15. using ZhonTai.DynamicApi;
  16. using ZhonTai.DynamicApi.Attributes;
  17. using ZhonTai.Admin.Core.Consts;
  18. using ZhonTai.Admin.Core.Configs;
  19. using ZhonTai.Admin.Domain.Org;
  20. using ZhonTai.Admin.Domain.Staff;
  21. using ZhonTai.Admin.Domain;
  22. namespace ZhonTai.Admin.Services.Tenant;
  23. /// <summary>
  24. /// 租户服务
  25. /// </summary>
  26. [DynamicApi(Area = AdminConsts.AreaName)]
  27. public class TenantService : BaseService, ITenantService, IDynamicApi
  28. {
  29. private readonly ITenantRepository _tenantRepository;
  30. private readonly IRoleRepository _roleRepository;
  31. private readonly IUserRepository _userRepository;
  32. private readonly IRepositoryBase<UserRoleEntity> _userRoleRepository;
  33. private readonly IRepositoryBase<RolePermissionEntity> _rolePermissionRepository;
  34. private IOrgRepository _orgRepository => LazyGetRequiredService<IOrgRepository>();
  35. private IStaffRepository _staffRepository => LazyGetRequiredService<IStaffRepository>();
  36. private IRepositoryBase<UserOrgEntity> _userOrgRepository => LazyGetRequiredService<IRepositoryBase<UserOrgEntity>>();
  37. private AppConfig _appConfig => LazyGetRequiredService<AppConfig>();
  38. public TenantService(
  39. ITenantRepository tenantRepository,
  40. IRoleRepository roleRepository,
  41. IUserRepository userRepository,
  42. IRepositoryBase<UserRoleEntity> userRoleRepository,
  43. IRepositoryBase<RolePermissionEntity> rolePermissionRepository
  44. )
  45. {
  46. _tenantRepository = tenantRepository;
  47. _roleRepository = roleRepository;
  48. _userRepository = userRepository;
  49. _userRoleRepository = userRoleRepository;
  50. _rolePermissionRepository = rolePermissionRepository;
  51. }
  52. /// <summary>
  53. /// 查询租户
  54. /// </summary>
  55. /// <param name="id"></param>
  56. /// <returns></returns>
  57. public async Task<IResultOutput> GetAsync(long id)
  58. {
  59. var result = await _tenantRepository.GetAsync<TenantGetOutput>(id);
  60. return ResultOutput.Ok(result);
  61. }
  62. /// <summary>
  63. /// 查询租户列表
  64. /// </summary>
  65. /// <param name="input"></param>
  66. /// <returns></returns>
  67. [HttpPost]
  68. public async Task<IResultOutput> GetPageAsync(PageInput<TenantGetPageDto> input)
  69. {
  70. var key = input.Filter?.Name;
  71. var list = await _tenantRepository.Select
  72. .WhereDynamicFilter(input.DynamicFilter)
  73. .WhereIf(key.NotNull(), a => a.Name.Contains(key))
  74. .Count(out var total)
  75. .OrderByDescending(true, c => c.Id)
  76. .Page(input.CurrentPage, input.PageSize)
  77. .ToListAsync<TenantListOutput>();
  78. var data = new PageOutput<TenantListOutput>()
  79. {
  80. List = list,
  81. Total = total
  82. };
  83. return ResultOutput.Ok(data);
  84. }
  85. /// <summary>
  86. /// 新增
  87. /// </summary>
  88. /// <param name="input"></param>
  89. /// <returns></returns>
  90. [Transaction]
  91. public virtual async Task<IResultOutput> AddAsync(TenantAddInput input)
  92. {
  93. if (await _tenantRepository.Select.AnyAsync(a => a.Name == input.Name))
  94. {
  95. return ResultOutput.NotOk($"企业名称已存在");
  96. }
  97. if (await _tenantRepository.Select.AnyAsync(a => a.Code == input.Code))
  98. {
  99. return ResultOutput.NotOk($"企业编码已存在");
  100. }
  101. //添加租户
  102. TenantEntity entity = Mapper.Map<TenantEntity>(input);
  103. TenantEntity tenant = await _tenantRepository.InsertAsync(entity);
  104. long tenantId = tenant.Id;
  105. //添加部门
  106. var org = new OrgEntity
  107. {
  108. TenantId = tenantId,
  109. Name = input.Name,
  110. Code = input.Code,
  111. ParentId = 0,
  112. MemberCount = 1
  113. };
  114. await _orgRepository.InsertAsync(org);
  115. //添加主管理员
  116. string pwd = MD5Encrypt.Encrypt32(_appConfig.DefaultPassword);
  117. var user = new UserEntity
  118. {
  119. TenantId = tenantId,
  120. UserName = input.Phone,
  121. Password = pwd,
  122. Name = input.RealName,
  123. Mobile = input.Phone,
  124. Email = input.Email,
  125. Status = UserStatus.Enabled,
  126. Type = UserType.TenantAdmin,
  127. MainOrgId = org.Id
  128. };
  129. await _userRepository.InsertAsync(user);
  130. long userId = user.Id;
  131. //添加员工
  132. var emp = new StaffEntity
  133. {
  134. Id = userId,
  135. TenantId = tenantId
  136. };
  137. await _staffRepository.InsertAsync(emp);
  138. //添加用户部门
  139. var userOrg = new UserOrgEntity
  140. {
  141. UserId = userId,
  142. OrgId = org.Id
  143. };
  144. await _userOrgRepository.InsertAsync(userOrg);
  145. //添加角色分组
  146. var roleGroup = new RoleEntity
  147. {
  148. TenantId = tenantId,
  149. Name = "系统默认",
  150. ParentId = 0
  151. };
  152. await _roleRepository.InsertAsync(roleGroup);
  153. //添加角色
  154. var role = new RoleEntity
  155. {
  156. TenantId = tenantId,
  157. Name = "主管理员",
  158. Code = "main-admin",
  159. ParentId = roleGroup.Id
  160. };
  161. await _roleRepository.InsertAsync(role);
  162. //添加用户角色
  163. var userRole = new UserRoleEntity()
  164. {
  165. UserId = userId,
  166. RoleId = role.Id
  167. };
  168. await _userRoleRepository.InsertAsync(userRole);
  169. //更新租户的用户
  170. tenant.UserId = userId;
  171. await _tenantRepository.UpdateAsync(tenant);
  172. return ResultOutput.Ok();
  173. }
  174. /// <summary>
  175. /// 修改
  176. /// </summary>
  177. /// <param name="input"></param>
  178. /// <returns></returns>
  179. public async Task<IResultOutput> UpdateAsync(TenantUpdateInput input)
  180. {
  181. if (!(input?.Id > 0))
  182. {
  183. return ResultOutput.NotOk();
  184. }
  185. var entity = await _tenantRepository.GetAsync(input.Id);
  186. if (!(entity?.Id > 0))
  187. {
  188. return ResultOutput.NotOk("租户不存在!");
  189. }
  190. Mapper.Map(input, entity);
  191. await _tenantRepository.UpdateAsync(entity);
  192. return ResultOutput.Ok();
  193. }
  194. /// <summary>
  195. /// 彻底删除
  196. /// </summary>
  197. /// <param name="id"></param>
  198. /// <returns></returns>
  199. [Transaction]
  200. public virtual async Task<IResultOutput> DeleteAsync(long id)
  201. {
  202. //删除角色权限
  203. await _rolePermissionRepository.Where(a => a.Role.TenantId == id).DisableGlobalFilter("Tenant").ToDelete().ExecuteAffrowsAsync();
  204. //删除用户角色
  205. await _userRoleRepository.Where(a => a.User.TenantId == id).DisableGlobalFilter("Tenant").ToDelete().ExecuteAffrowsAsync();
  206. //删除员工
  207. await _staffRepository.Where(a => a.TenantId == id).DisableGlobalFilter("Tenant").ToDelete().ExecuteAffrowsAsync();
  208. //删除用户部门
  209. await _userOrgRepository.Where(a => a.User.TenantId == id).DisableGlobalFilter("Tenant").ToDelete().ExecuteAffrowsAsync();
  210. //删除用户
  211. await _userRepository.Where(a => a.TenantId == id).DisableGlobalFilter("Tenant").ToDelete().ExecuteAffrowsAsync();
  212. //删除角色
  213. await _roleRepository.Where(a => a.TenantId == id).DisableGlobalFilter("Tenant").ToDelete().ExecuteAffrowsAsync();
  214. //删除租户
  215. await _tenantRepository.DeleteAsync(id);
  216. return ResultOutput.Ok();
  217. }
  218. /// <summary>
  219. /// 删除
  220. /// </summary>
  221. /// <param name="id"></param>
  222. /// <returns></returns>
  223. [Transaction]
  224. public virtual async Task<IResultOutput> SoftDeleteAsync(long id)
  225. {
  226. //删除用户
  227. await _userRepository.SoftDeleteAsync(a => a.TenantId == id, "Tenant");
  228. //删除角色
  229. await _roleRepository.SoftDeleteAsync(a => a.TenantId == id, "Tenant");
  230. //删除租户
  231. var result = await _tenantRepository.SoftDeleteAsync(id);
  232. return ResultOutput.Result(result);
  233. }
  234. /// <summary>
  235. /// 批量删除
  236. /// </summary>
  237. /// <param name="ids"></param>
  238. /// <returns></returns>
  239. [Transaction]
  240. public virtual async Task<IResultOutput> BatchSoftDeleteAsync(long[] ids)
  241. {
  242. //删除用户
  243. await _userRepository.SoftDeleteAsync(a => ids.Contains(a.TenantId.Value), "Tenant");
  244. //删除角色
  245. await _roleRepository.SoftDeleteAsync(a => ids.Contains(a.TenantId.Value), "Tenant");
  246. //删除租户
  247. var result = await _tenantRepository.SoftDeleteAsync(ids);
  248. return ResultOutput.Result(result);
  249. }
  250. }