颐和api

RoleInfoController.cs 9.1KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Threading.Tasks;
  5. using Microsoft.AspNetCore.Mvc;
  6. using Microsoft.Extensions.Logging;
  7. using Microsoft.AspNetCore.Authorization;
  8. using Api.SignToken;
  9. using MadRunFabric.Common;
  10. using System.Threading;
  11. using System.Security.Claims;
  12. using ConfigurationApi.IRepositories;
  13. using MongoDB.Driver;
  14. using MadRunFabric.Model;
  15. using ConfigurationApi.Model.Input;
  16. // For more information on enabling Web API for empty projects, visit https://go.microsoft.com/fwlink/?LinkID=397860
  17. namespace ConfigurationApi.Controllers
  18. {
  19. [Authorize]
  20. [Route("api/[controller]")]
  21. public class RoleInfoController : BaseController
  22. {
  23. private readonly ILogger<RoleInfoController> _logger;
  24. private readonly ISys_Role_InfoRepository _sys_role_infoRepository;
  25. private readonly ISys_User_AccountRepository _sys_user_accountRepository;
  26. public RoleInfoController(
  27. ISys_Role_InfoRepository sys_role_infoRepository,
  28. ISys_User_AccountRepository sys_user_accountRepository,
  29. ILogger<RoleInfoController> logger)
  30. {
  31. _sys_role_infoRepository = sys_role_infoRepository;
  32. _sys_user_accountRepository = sys_user_accountRepository;
  33. _logger = logger;
  34. }
  35. /// <summary>
  36. /// 获取角色下拉列表
  37. /// </summary>
  38. /// <returns></returns>
  39. [HttpGet("getlistdrop")]
  40. public async Task<IActionResult> GetListDropAsync()
  41. {
  42. var list = (await _sys_role_infoRepository.Get(x => x.state_flag == 1)).OrderBy(x => x.sort);
  43. return Success("获取全部数据成功", list);
  44. }
  45. /// <summary>
  46. /// 获取角色分页
  47. /// </summary>
  48. /// <param name="keyword"></param>
  49. /// <param name="pageindex"></param>
  50. /// <param name="pagesize"></param>
  51. /// <returns></returns>
  52. [HttpGet("getlistbypage")]
  53. public async Task<IActionResult> GetListsByPageAsync(string keyword,string stime,string etime, int pageindex = 1, int pagesize = 10)
  54. {
  55. #region 条件信息
  56. ////排序字段
  57. var sort = Builders<Sys_Role_Info>.Sort.Descending("sort").Descending("create_time");
  58. var list = await _sys_role_infoRepository.GetByPage(null, pageindex, pagesize, sort);
  59. var redCount = await _sys_role_infoRepository.CountAsync(null); //获取总数
  60. //根据条件查询集合
  61. var listApp = new List<FilterDefinition<Sys_Role_Info>>();
  62. listApp.Add(Builders<Sys_Role_Info>.Filter.Eq("state_flag", 1));
  63. //模糊查询
  64. if (!string.IsNullOrEmpty(keyword))
  65. listApp.Add(Builders<Sys_Role_Info>.Filter.Where(s => s.role_code.Contains(keyword) || s.role_name.Contains(keyword)));
  66. if (!string.IsNullOrWhiteSpace(stime))
  67. {
  68. listApp.Add(Builders<Sys_Role_Info>.Filter.Where(s => s.create_time.CompareTo(DateTime.Parse(stime + " 00:00:00")) >= 0 ));
  69. }
  70. if (!string.IsNullOrWhiteSpace(etime))
  71. {
  72. listApp.Add(Builders<Sys_Role_Info>.Filter.Where(s => s.create_time.CompareTo(DateTime.Parse(etime + " 23:59:59")) <= 0 ));
  73. }
  74. #endregion
  75. int recordCount = 0;
  76. if (listApp.Count > 0)
  77. {
  78. var filter = Builders<Sys_Role_Info>.Filter.And(listApp);
  79. list = await _sys_role_infoRepository.GetByPage(filter, pageindex, pagesize, sort);
  80. redCount = await _sys_role_infoRepository.CountAsync(filter); //获取总数
  81. }
  82. recordCount = int.Parse(redCount.ToString());
  83. var obj = new
  84. {
  85. state = "success",
  86. message = "成功",
  87. rows = list,
  88. total = recordCount,
  89. };
  90. return Content(obj.ToJson());
  91. }
  92. /// <summary>
  93. /// 获取角色
  94. /// </summary>
  95. /// <param name="id">角色id</param>
  96. /// <returns></returns>
  97. [HttpGet("getdetailes")]
  98. public async Task<IActionResult> GetDetailsAsync(string id)
  99. {
  100. if (string.IsNullOrEmpty(id))
  101. return Error("参数错误");
  102. var model = await _sys_role_infoRepository.GetSingle(id);
  103. if (model == null)
  104. {
  105. return Error("获取失败");
  106. }
  107. return Success("获取成功!", model);
  108. }
  109. /// <summary>
  110. /// 添加角色
  111. /// </summary>
  112. /// <param name="input"></param>
  113. /// <returns></returns>
  114. [HttpPost("add")]
  115. public async Task<IActionResult> AddAsync(RoleInfoInput input)
  116. {
  117. if (string.IsNullOrEmpty(input.role_name))
  118. return Error("请输入角色名称");
  119. if (string.IsNullOrEmpty(input.role_Code))
  120. return Error("请输入角色代码");
  121. var model = new Sys_Role_Info();
  122. model.role_name = input.role_name;
  123. model.role_remark = input.role_remark;
  124. model.role_code = input.role_Code;
  125. model.project_num = input.project_num;
  126. model.sort = input.sort;
  127. model.create_uid= User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  128. if (await _sys_role_infoRepository.Count(x => x.role_code == input.role_Code&&x.state_flag !=2) > 0)//2019-5-27添加删除判断
  129. {
  130. return Error("添加失败,存在相同的角色代码");
  131. }
  132. if (await _sys_role_infoRepository.Add(model))
  133. {
  134. return Success("添加成功");
  135. }
  136. else
  137. {
  138. return Error("添加失败");
  139. }
  140. }
  141. /// <summary>
  142. /// 修改角色信息
  143. /// </summary>
  144. [HttpPost("update")]
  145. public async Task<IActionResult> UpdateAsync(RoleInfoInput input)
  146. {
  147. if (string.IsNullOrEmpty(input.role_name))
  148. return Error("请输入角色名称");
  149. if (string.IsNullOrEmpty(input.role_Code))
  150. return Error("请输入角色代码");
  151. var model = await _sys_role_infoRepository.GetSingle(input.role_id);
  152. if (model == null)
  153. return Error("操作失败");
  154. model.role_name = input.role_name;
  155. model.role_code = input.role_Code;
  156. model.role_remark = input.role_remark;
  157. model.project_num = input.project_num;
  158. model.sort = input.sort;
  159. model.lastmodify_time = DateTime.Now.ToLocalTime();
  160. model.lastmodify_uid = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  161. bool b = await _sys_role_infoRepository.Update(model);
  162. if (b)
  163. return Success("修改成功");
  164. return Error("修改失败");
  165. }
  166. /// <summary>
  167. /// 删除角色信息 by ids
  168. /// </summary>
  169. /// <param name="ids"></param>
  170. /// <returns></returns>
  171. [HttpPost("delete")]
  172. public async Task<IActionResult> Remove(string[] ids)
  173. {
  174. var res = 0;
  175. if (ids != null && ids.Length > 0)
  176. {
  177. foreach (var item in ids)
  178. {
  179. var ml = await _sys_role_infoRepository.GetSingle(item);
  180. ml.state_flag = 2;
  181. ml.delete_time = DateTime.Now.ToLocalTime();
  182. ml.delete_uid = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  183. if (_sys_role_infoRepository.Update(ml).Result)
  184. res += 1;
  185. }
  186. if (res == ids.Length)
  187. return Success("删除成功");
  188. else if (res > 0 && res < ids.Length)
  189. return Error("部分删除失败,请查看后重新操作");
  190. else
  191. return Error("删除失败,请查看后重新操作");
  192. }
  193. else
  194. return Error("请选择要删除的记录");
  195. }
  196. #region 获取角色和人员 - 二级
  197. /// <summary>
  198. /// 获取角色和人员列表 - 二级
  199. /// </summary>
  200. [HttpGet("getroleuserlist")]
  201. public async Task<IActionResult> GetTreeListAsync()
  202. {
  203. var listRole = (await _sys_role_infoRepository.Get(p => p.state_flag == 1)).ToList();
  204. var listUser = (await _sys_user_accountRepository.Get(p => p.delete_flag == false)).ToList();
  205. var list1 = listRole.Select(p => new
  206. {
  207. id = p.id,
  208. type = "role",
  209. code = p.role_code,
  210. name = p.role_name
  211. });
  212. var list2 = listUser.Select(p => new
  213. {
  214. id = p.id,
  215. type = "user",
  216. code = p.usercode,
  217. name = p.username
  218. });
  219. var list = list1.Union(list2);
  220. return Success("获取成功", list);
  221. }
  222. #endregion
  223. }
  224. }