足力健后端,使用.netcore版本,合并1个项目使用

RoleInfoController.cs 7.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189
  1. using System;
  2. using System.Collections.Generic;
  3. using System.IRepositories;
  4. using System.Linq;
  5. using System.Model;
  6. using System.Security.Claims;
  7. using System.Threading.Tasks;
  8. using System.Common;
  9. using Microsoft.AspNetCore.Authorization;
  10. using Microsoft.AspNetCore.Mvc;
  11. using SqlSugar;
  12. using TVShoppingCallCenter_ZLJ.Models.Inputs;
  13. namespace TVShoppingCallCenter_ZLJ.Controllers.System
  14. {
  15. [Authorize]
  16. [Produces("application/json")]
  17. [Route("api/[controller]")]
  18. public class RoleInfoController : BaseController
  19. {
  20. private readonly ISys_RoleInfoRepository _sys_role_infoRepository;
  21. public RoleInfoController(ISys_RoleInfoRepository sys_role_infoRepository)
  22. {
  23. _sys_role_infoRepository = sys_role_infoRepository;
  24. }
  25. /// <summary>
  26. /// 获取角色分页
  27. /// </summary>
  28. /// <param name="keyword"></param>
  29. /// <param name="pageindex"></param>
  30. /// <param name="pagesize"></param>
  31. /// <returns></returns>
  32. [HttpGet("getlistbypage")]
  33. public async Task<IActionResult> GetListsByPageAsync(string keyword, int pageindex = 1, int pagesize = 20)
  34. {
  35. List<IConditionalModel> conModels = new List<IConditionalModel>();
  36. #region 条件筛选
  37. conModels.Add(new ConditionalModel() { FieldName = "F_State", ConditionalType = ConditionalType.Equal, FieldValue = ((int)EnumDelState.Enabled).ToString() });
  38. if (!string.IsNullOrEmpty(keyword))
  39. {
  40. conModels.Add(new ConditionalModel() { FieldName = "F_RoleCode", ConditionalType = ConditionalType.Like, FieldValue = keyword });
  41. }
  42. #endregion
  43. int recordCount = 0;
  44. var list = await _sys_role_infoRepository.GetListByPage(conModels, new MyPageModel() { PageIndex = pageindex, PageSize = pagesize, PageCount = recordCount }, "F_CreateOn desc");
  45. return Success("获取数据成功", list);
  46. }
  47. /// <summary>
  48. /// 获取角色下拉列表
  49. /// </summary>
  50. /// <returns></returns>
  51. [HttpGet("getlistdrop")]
  52. public async Task<IActionResult> GetListDropAsync()
  53. {
  54. var list = await _sys_role_infoRepository.GetListALL(x => x.F_State == (int)EnumDelState.Enabled, o => o.F_CreateOn, OrderByType.Desc);
  55. var result = list.Select(x => new {
  56. x.F_RoleCode,
  57. x.F_RoleName,
  58. x.F_RoleId
  59. });
  60. return Success("获取全部数据成功", result);
  61. }
  62. /// <summary>
  63. /// 获取角色
  64. /// </summary>
  65. /// <param name="id">角色id</param>
  66. /// <returns></returns>
  67. [HttpGet("getdetails")]
  68. public async Task<IActionResult> GetDetailsAsync(int id)
  69. {
  70. if (id <= 0)
  71. return Error("参数错误");
  72. var model = await _sys_role_infoRepository.GetSingle(x => x.F_RoleId == id && x.F_State == (int)EnumDelState.Enabled);
  73. if (model == null)
  74. {
  75. return Error("获取失败");
  76. }
  77. return Success("获取成功!", model);
  78. }
  79. /// <summary>
  80. /// 添加角色
  81. /// </summary>
  82. /// <param name="input"></param>
  83. /// <returns></returns>
  84. [HttpPost("add")]
  85. public async Task<IActionResult> AddAsync(RoleInfoInput input)
  86. {
  87. if (string.IsNullOrEmpty(input.role_name))
  88. return Error("请输入角色名称");
  89. if (string.IsNullOrEmpty(input.role_Code))
  90. return Error("请输入角色代码");
  91. if(input.role_name.Length>15)
  92. return Error("角色名称长度不能超过15");
  93. if (input.role_Code.Length > 15)
  94. return Error("角色代码长度不能超过15");
  95. var model = new T_Sys_RoleInfo();
  96. model.F_RoleName = input.role_name;
  97. model.F_Remark = input.role_remark;
  98. model.F_RoleCode = input.role_Code;
  99. model.F_State = input.state;
  100. model.F_CreateBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  101. model.F_CreateOn = DateTime.Now;
  102. if (await _sys_role_infoRepository.GetCount(x => x.F_RoleCode == input.role_Code && x.F_State != 2) > 0)
  103. {
  104. return Error("添加失败,存在相同的角色代码");
  105. }
  106. var res = await _sys_role_infoRepository.Add(model);
  107. if (res>0)
  108. {
  109. return Success("添加成功");
  110. }
  111. else
  112. {
  113. return Error("添加失败");
  114. }
  115. }
  116. /// <summary>
  117. /// 修改角色信息
  118. /// </summary>
  119. [HttpPost("update")]
  120. public async Task<IActionResult> UpdateAsync(RoleInfoInput input)
  121. {
  122. if (string.IsNullOrEmpty(input.role_name))
  123. return Error("请输入角色名称");
  124. if (string.IsNullOrEmpty(input.role_Code))
  125. return Error("请输入角色代码");
  126. var model = await _sys_role_infoRepository.GetSingle(x => x.F_RoleId == input.role_id && x.F_State == (int)EnumDelState.Enabled);
  127. if (model == null)
  128. return Error("操作失败");
  129. model.F_RoleName = input.role_name;
  130. model.F_Remark = input.role_remark;
  131. model.F_RoleCode = input.role_Code;
  132. model.F_LastModifyOn = DateTime.Now.ToLocalTime();
  133. model.F_LastModifyBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  134. if (await _sys_role_infoRepository.GetCount(x => x.F_RoleCode == input.role_Code && x.F_RoleId !=input.role_id && x.F_State != 2) > 0)
  135. {
  136. return Error("修改失败,存在相同的角色代码");
  137. }
  138. bool b = await _sys_role_infoRepository.Update(model);
  139. if (b)
  140. return Success("修改成功");
  141. return Error("修改失败");
  142. }
  143. /// <summary>
  144. /// 删除角色信息 by ids
  145. /// </summary>
  146. /// <param name="ids"></param>
  147. /// <returns></returns>
  148. [HttpPost("delete")]
  149. public async Task<IActionResult> Remove(int[] ids)
  150. {
  151. var res = 0;
  152. if (ids != null && ids.Length > 0)
  153. {
  154. foreach (var item in ids)
  155. {
  156. var ml = await _sys_role_infoRepository.GetSingle(x => x.F_RoleId == item);
  157. ml.F_State = (int)EnumDelState.Delete;
  158. ml.F_DeleteOn = DateTime.Now.ToLocalTime();
  159. ml.F_DeleteBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  160. if (_sys_role_infoRepository.Update(ml).Result)
  161. res += 1;
  162. }
  163. if (res == ids.Length)
  164. return Success("删除成功");
  165. else if (res > 0 && res < ids.Length)
  166. return Error("部分删除失败,请查看后重新操作");
  167. else
  168. return Error("删除失败,请查看后重新操作");
  169. }
  170. else
  171. return Error("请选择要删除的记录");
  172. }
  173. }
  174. }