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

RoleInfoController.cs 6.5KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172
  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. private readonly ISys_UserAccountRepository _sys_user_accountRepository;
  22. public RoleInfoController(ISys_RoleInfoRepository sys_role_infoRepository, ISys_UserAccountRepository sys_user_accountRepository)
  23. {
  24. _sys_role_infoRepository = sys_role_infoRepository;
  25. _sys_user_accountRepository = sys_user_accountRepository;
  26. }
  27. /// <summary>
  28. /// 获取角色分页
  29. /// </summary>
  30. /// <param name="keyword"></param>
  31. /// <param name="pageindex"></param>
  32. /// <param name="pagesize"></param>
  33. /// <returns></returns>
  34. [HttpGet("getlistbypage")]
  35. public async Task<IActionResult> GetListsByPageAsync(string keyword, int pageindex = 1, int pagesize = 20)
  36. {
  37. List<IConditionalModel> conModels = new List<IConditionalModel>();
  38. #region 条件筛选
  39. conModels.Add(new ConditionalModel() { FieldName = "F_State", ConditionalType = ConditionalType.Equal, FieldValue = ((int)EnumDelState.Enabled).ToString() });
  40. if (!string.IsNullOrEmpty(keyword))
  41. {
  42. conModels.Add(new ConditionalModel() { FieldName = "F_RoleCode", ConditionalType = ConditionalType.Like, FieldValue = keyword });
  43. }
  44. #endregion
  45. int recordCount = 0;
  46. var list = await _sys_role_infoRepository.GetListByPage(conModels, new PageModel() { PageIndex = pageindex, PageSize = pagesize, PageCount = recordCount });
  47. var obj = new
  48. {
  49. state = "success",
  50. message = "成功",
  51. rows = list,
  52. total = recordCount,
  53. };
  54. return Content(obj.ToJson());
  55. }
  56. /// <summary>
  57. /// 获取角色
  58. /// </summary>
  59. /// <param name="id">角色id</param>
  60. /// <returns></returns>
  61. [HttpGet("getdetailes")]
  62. public async Task<IActionResult> GetDetailsAsync(int id)
  63. {
  64. if (id <= 0)
  65. return Error("参数错误");
  66. var model = await _sys_role_infoRepository.GetSingle(x => x.F_RoleId == id);
  67. if (model == null)
  68. {
  69. return Error("获取失败");
  70. }
  71. return Success("获取成功!", model);
  72. }
  73. /// <summary>
  74. /// 添加角色
  75. /// </summary>
  76. /// <param name="input"></param>
  77. /// <returns></returns>
  78. [HttpPost("add")]
  79. public async Task<IActionResult> AddAsync(RoleInfoInput input)
  80. {
  81. if (string.IsNullOrEmpty(input.role_name))
  82. return Error("请输入角色名称");
  83. if (string.IsNullOrEmpty(input.role_Code))
  84. return Error("请输入角色代码");
  85. var model = new T_Sys_RoleInfo();
  86. model.F_RoleName = input.role_name;
  87. model.F_Remark = input.role_remark;
  88. model.F_RoleCode = input.role_Code;
  89. model.F_State = input.state;
  90. model.F_CreateBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  91. model.F_CreateOn = DateTime.Now;
  92. if (await _sys_role_infoRepository.GetCount(x => x.F_RoleCode == input.role_Code && x.F_State != 2) > 0)
  93. {
  94. return Error("添加失败,存在相同的角色代码");
  95. }
  96. var res = await _sys_role_infoRepository.Add(model);
  97. if (res>0)
  98. {
  99. return Success("添加成功");
  100. }
  101. else
  102. {
  103. return Error("添加失败");
  104. }
  105. }
  106. /// <summary>
  107. /// 修改角色信息
  108. /// </summary>
  109. [HttpPost("update")]
  110. public async Task<IActionResult> UpdateAsync(RoleInfoInput input)
  111. {
  112. if (string.IsNullOrEmpty(input.role_name))
  113. return Error("请输入角色名称");
  114. if (string.IsNullOrEmpty(input.role_Code))
  115. return Error("请输入角色代码");
  116. var model = await _sys_role_infoRepository.GetSingle(x => x.F_RoleId == input.role_id);
  117. if (model == null)
  118. return Error("操作失败");
  119. model.F_RoleName = input.role_name;
  120. model.F_Remark = input.role_remark;
  121. model.F_RoleCode = input.role_Code;
  122. model.F_LastModifyOn = DateTime.Now.ToLocalTime();
  123. model.F_LastModifyBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  124. bool b = await _sys_role_infoRepository.Update(model);
  125. if (b)
  126. return Success("修改成功");
  127. return Error("修改失败");
  128. }
  129. /// <summary>
  130. /// 删除角色信息 by ids
  131. /// </summary>
  132. /// <param name="ids"></param>
  133. /// <returns></returns>
  134. [HttpPost("delete")]
  135. public async Task<IActionResult> Remove(int[] ids)
  136. {
  137. var res = 0;
  138. if (ids != null && ids.Length > 0)
  139. {
  140. foreach (var item in ids)
  141. {
  142. var ml = await _sys_role_infoRepository.GetSingle(x => x.F_RoleId == item);
  143. ml.F_State = (int)EnumDelState.Delete;
  144. ml.F_DeleteOn = DateTime.Now.ToLocalTime();
  145. ml.F_DeleteBy = User.Claims.FirstOrDefault(c => c.Type == ClaimTypes.Sid).Value;
  146. if (_sys_role_infoRepository.Update(ml).Result)
  147. res += 1;
  148. }
  149. if (res == ids.Length)
  150. return Success("删除成功");
  151. else if (res > 0 && res < ids.Length)
  152. return Error("部分删除失败,请查看后重新操作");
  153. else
  154. return Error("删除失败,请查看后重新操作");
  155. }
  156. else
  157. return Error("请选择要删除的记录");
  158. }
  159. }
  160. }