PermissionRoleController.cs 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391
  1. using LeaRun.Application.Busines.AuthorizeManage;
  2. using LeaRun.Application.Busines.BaseManage;
  3. using LeaRun.Application.Cache;
  4. using LeaRun.Application.Code;
  5. using LeaRun.Application.Entity.AuthorizeManage;
  6. using LeaRun.Application.Entity.BaseManage;
  7. using LeaRun.Util;
  8. using LeaRun.Util.Extension;
  9. using LeaRun.Util.WebControl;
  10. using System;
  11. using System.Collections.Generic;
  12. using System.Data;
  13. using System.Linq;
  14. using System.Web.Mvc;
  15. namespace LeaRun.Application.Web.Areas.AuthorizeManage.Controllers
  16. {
  17. /// <summary>
  18. /// 版 本
  19. /// Copyright (c) 2013-2016 上海力软信息技术有限公司
  20. /// 创建人:佘赐雄
  21. /// 日 期:2015.11.3 5:35
  22. /// 描 述:角色权限
  23. /// </summary>
  24. public class PermissionRoleController : MvcControllerBase
  25. {
  26. private OrganizeBLL organizeBLL = new OrganizeBLL();
  27. private DepartmentBLL departmentBLL = new DepartmentBLL();
  28. private DepartmentCache departmentCache = new DepartmentCache();
  29. private RoleBLL roleBLL = new RoleBLL();
  30. private UserBLL userBLL = new UserBLL();
  31. private PermissionBLL permissionBLL = new PermissionBLL();
  32. private AuthorizeBLL authorizeBLL = new AuthorizeBLL();
  33. #region 视图功能
  34. /// <summary>
  35. /// 角色权限
  36. /// </summary>
  37. /// <returns></returns>
  38. [HttpGet]
  39. [HandlerAuthorize(PermissionMode.Enforce)]
  40. public ActionResult AllotAuthorize()
  41. {
  42. return View();
  43. }
  44. /// <summary>
  45. /// 角色成员
  46. /// </summary>
  47. /// <returns></returns>
  48. [HttpGet]
  49. [HandlerAuthorize(PermissionMode.Enforce)]
  50. public ActionResult AllotMember()
  51. {
  52. return View();
  53. }
  54. #endregion
  55. #region 获取数据
  56. /// <summary>
  57. /// 部门列表
  58. /// </summary>
  59. /// <param name="roleId">角色Id</param>
  60. /// <param name="keyword">关键字</param>
  61. /// <returns>返回树形Json</returns>
  62. [HttpGet]
  63. public ActionResult GetDepartmentTreeJson(string roleId)
  64. {
  65. var roleEntity = roleBLL.GetEntity(roleId);
  66. var organizeEntity = organizeBLL.GetEntity(roleEntity.OrganizeId);
  67. var data = departmentCache.GetList(roleEntity.OrganizeId);
  68. var treeList = new List<TreeEntity>();
  69. TreeEntity tree = new TreeEntity();
  70. tree.id = organizeEntity.OrganizeId;
  71. tree.text = organizeEntity.FullName;
  72. tree.value = organizeEntity.OrganizeId;
  73. tree.isexpand = true;
  74. tree.complete = true;
  75. tree.hasChildren = true;
  76. tree.parentId = "0";
  77. treeList.Add(tree);
  78. foreach (DepartmentEntity item in data)
  79. {
  80. tree = new TreeEntity();
  81. bool hasChildren = data.Count(t => t.ParentId == item.DepartmentId) == 0 ? false : true;
  82. tree.id = item.DepartmentId;
  83. tree.text = item.FullName;
  84. tree.value = item.DepartmentId;
  85. if (item.ParentId == "0")
  86. {
  87. tree.parentId = roleEntity.OrganizeId;
  88. }
  89. else
  90. {
  91. tree.parentId = item.ParentId;
  92. }
  93. tree.isexpand = true;
  94. tree.complete = true;
  95. tree.hasChildren = hasChildren;
  96. treeList.Add(tree);
  97. }
  98. return Content(treeList.TreeToJson());
  99. }
  100. /// <summary>
  101. /// 用户列表
  102. /// </summary>
  103. /// <param name="roleId">角色Id</param>
  104. /// <returns></returns>
  105. [HttpGet]
  106. public ActionResult GetUserListJson(string roleId)
  107. {
  108. var existMember = permissionBLL.GetMemberList(roleId);
  109. var userdata = userBLL.GetTable();
  110. userdata.Columns.Add("ischeck", Type.GetType("System.Int32"));
  111. userdata.Columns.Add("isdefault", Type.GetType("System.Int32"));
  112. foreach (DataRow item in userdata.Rows)
  113. {
  114. string UserId = item["userid"].ToString();
  115. int ischeck = existMember.Count(t => t.UserId == UserId);
  116. item["ischeck"] = ischeck;
  117. if (ischeck > 0)
  118. {
  119. item["isdefault"] = existMember.First(t => t.UserId == UserId).IsDefault;
  120. }
  121. else
  122. {
  123. item["isdefault"] = 0;
  124. }
  125. }
  126. userdata = DataHelper.DataFilter(userdata, "", "ischeck desc");
  127. return Content(userdata.ToJson());
  128. }
  129. /// <summary>
  130. /// 系统功能列表
  131. /// </summary>
  132. /// <param name="RoleId">角色Id</param>
  133. /// <returns></returns>
  134. [HttpGet]
  135. public ActionResult ModuleTreeJson(string roleId)
  136. {
  137. var existModule = permissionBLL.GetModuleList(roleId);
  138. var data = authorizeBLL.GetModuleList(SystemInfo.CurrentUserId);
  139. var treeList = new List<TreeEntity>();
  140. foreach (ModuleEntity item in data)
  141. {
  142. TreeEntity tree = new TreeEntity();
  143. bool hasChildren = data.Count(t => t.ParentId == item.ModuleId) == 0 ? false : true;
  144. tree.id = item.ModuleId;
  145. tree.text = item.FullName;
  146. tree.value = item.ModuleId;
  147. tree.title = "";
  148. tree.checkstate = existModule.Count(t => t.ItemId == item.ModuleId);
  149. tree.showcheck = true;
  150. tree.isexpand = true;
  151. tree.complete = true;
  152. tree.hasChildren = hasChildren;
  153. tree.parentId = item.ParentId;
  154. tree.img = item.Icon;
  155. treeList.Add(tree);
  156. }
  157. return Content(treeList.TreeToJson());
  158. }
  159. /// <summary>
  160. /// 系统按钮列表
  161. /// </summary>
  162. /// <param name="roleId">角色Id</param>
  163. /// <returns></returns>
  164. [HttpGet]
  165. public ActionResult ModuleButtonTreeJson(string roleId)
  166. {
  167. var existModuleButton = permissionBLL.GetModuleButtonList(roleId);
  168. var moduleData = authorizeBLL.GetModuleList(SystemInfo.CurrentUserId);
  169. var moduleButtonData = authorizeBLL.GetModuleButtonList(SystemInfo.CurrentUserId);
  170. var treeList = new List<TreeEntity>();
  171. foreach (ModuleEntity item in moduleData)
  172. {
  173. if (item.IsMenu == 1)
  174. {
  175. bool hasChildren = moduleButtonData.Count(t => t.ModuleId == item.ModuleId) == 0 ? false : true;
  176. if (hasChildren == false)
  177. {
  178. continue;
  179. }
  180. }
  181. TreeEntity tree = new TreeEntity();
  182. tree.id = item.ModuleId;
  183. tree.text = item.FullName;
  184. tree.value = item.ModuleId;
  185. tree.checkstate = existModuleButton.Count(t => t.ItemId == item.ModuleId);
  186. tree.showcheck = true;
  187. tree.isexpand = true;
  188. tree.complete = true;
  189. tree.hasChildren = true;
  190. tree.parentId = item.ParentId;
  191. tree.img = item.Icon;
  192. treeList.Add(tree);
  193. }
  194. foreach (ModuleButtonEntity item in moduleButtonData)
  195. {
  196. TreeEntity tree = new TreeEntity();
  197. bool hasChildren = moduleButtonData.Count(t => t.ParentId == item.ModuleButtonId) == 0 ? false : true;
  198. tree.id = item.ModuleButtonId;
  199. tree.text = item.FullName;
  200. tree.value = item.ModuleButtonId;
  201. if (item.ParentId == "0")
  202. {
  203. tree.parentId = item.ModuleId;
  204. }
  205. else
  206. {
  207. tree.parentId = item.ParentId;
  208. }
  209. tree.checkstate = existModuleButton.Count(t => t.ItemId == item.ModuleButtonId);
  210. tree.showcheck = true;
  211. tree.isexpand = true;
  212. tree.complete = true;
  213. tree.img = "fa fa-wrench " + item.ModuleId;
  214. tree.hasChildren = hasChildren;
  215. treeList.Add(tree);
  216. }
  217. return Content(treeList.TreeToJson());
  218. }
  219. /// <summary>
  220. /// 系统视图列表
  221. /// </summary>
  222. /// <param name="roleId">角色Id</param>
  223. /// <returns></returns>
  224. [HttpGet]
  225. public ActionResult ModuleColumnTreeJson(string roleId)
  226. {
  227. var existModuleColumn = permissionBLL.GetModuleColumnList(roleId);
  228. var moduleData = authorizeBLL.GetModuleList(SystemInfo.CurrentUserId);
  229. var moduleColumnData = authorizeBLL.GetModuleColumnList(SystemInfo.CurrentUserId);
  230. var treeList = new List<TreeEntity>();
  231. foreach (ModuleEntity item in moduleData)
  232. {
  233. TreeEntity tree = new TreeEntity();
  234. tree.id = item.ModuleId;
  235. tree.text = item.FullName;
  236. tree.value = item.ModuleId;
  237. tree.checkstate = existModuleColumn.Count(t => t.ItemId == item.ModuleId);
  238. tree.showcheck = true;
  239. tree.isexpand = true;
  240. tree.complete = true;
  241. tree.hasChildren = true;
  242. tree.parentId = item.ParentId;
  243. tree.img = item.Icon;
  244. treeList.Add(tree);
  245. }
  246. foreach (ModuleColumnEntity item in moduleColumnData)
  247. {
  248. TreeEntity tree = new TreeEntity();
  249. bool hasChildren = moduleColumnData.Count(t => t.ParentId == item.ModuleColumnId) == 0 ? false : true;
  250. tree.id = item.ModuleColumnId;
  251. tree.text = item.FullName;
  252. tree.value = item.ModuleColumnId;
  253. if (item.ParentId == "0")
  254. {
  255. tree.parentId = item.ModuleId;
  256. }
  257. else
  258. {
  259. tree.parentId = item.ParentId;
  260. }
  261. tree.checkstate = existModuleColumn.Count(t => t.ItemId == item.ModuleColumnId);
  262. tree.showcheck = true;
  263. tree.isexpand = true;
  264. tree.complete = true;
  265. tree.img = "fa fa-filter " + item.ModuleId;
  266. tree.hasChildren = hasChildren;
  267. treeList.Add(tree);
  268. }
  269. return Content(treeList.TreeToJson());
  270. }
  271. /// <summary>
  272. /// 数据权限列表
  273. /// </summary>
  274. /// <param name="roleId">角色Id</param>
  275. /// <returns></returns>
  276. [HttpGet]
  277. public ActionResult OrganizeTreeJson(string roleId)
  278. {
  279. var existAuthorizeData = permissionBLL.GetAuthorizeDataList(roleId);
  280. var organizedata = organizeBLL.GetList();
  281. var departmentdata = departmentBLL.GetList();
  282. var treeList = new List<TreeEntity>();
  283. foreach (OrganizeEntity item in organizedata)
  284. {
  285. TreeEntity tree = new TreeEntity();
  286. bool hasChildren = organizedata.Count(t => t.ParentId == item.OrganizeId) == 0 ? false : true;
  287. if (hasChildren == false)
  288. {
  289. hasChildren = departmentdata.Count(t => t.OrganizeId == item.OrganizeId) == 0 ? false : true;
  290. if (hasChildren == false)
  291. {
  292. continue;
  293. }
  294. }
  295. tree.id = item.OrganizeId;
  296. tree.text = item.FullName;
  297. tree.value = item.OrganizeId;
  298. tree.parentId = item.ParentId;
  299. if (item.ParentId == "0")
  300. {
  301. tree.img = "fa fa-sitemap";
  302. }
  303. else
  304. {
  305. tree.img = "fa fa-home";
  306. }
  307. tree.checkstate = existAuthorizeData.Count(t => t.ResourceId == item.OrganizeId);
  308. tree.showcheck = true;
  309. tree.isexpand = true;
  310. tree.complete = true;
  311. tree.hasChildren = hasChildren;
  312. treeList.Add(tree);
  313. }
  314. foreach (DepartmentEntity item in departmentdata)
  315. {
  316. TreeEntity tree = new TreeEntity();
  317. bool hasChildren = departmentdata.Count(t => t.ParentId == item.DepartmentId) == 0 ? false : true;
  318. tree.id = item.DepartmentId;
  319. tree.text = item.FullName;
  320. tree.value = item.DepartmentId;
  321. if (item.ParentId == "0")
  322. {
  323. tree.parentId = item.OrganizeId;
  324. }
  325. else
  326. {
  327. tree.parentId = item.ParentId;
  328. }
  329. tree.checkstate = existAuthorizeData.Count(t => t.ResourceId == item.DepartmentId);
  330. tree.showcheck = true;
  331. tree.isexpand = true;
  332. tree.complete = true;
  333. tree.img = "fa fa-umbrella";
  334. tree.hasChildren = hasChildren;
  335. treeList.Add(tree);
  336. }
  337. int authorizeType = -1;
  338. if (existAuthorizeData.ToList().Count > 0)
  339. {
  340. authorizeType = existAuthorizeData.ToList()[0].AuthorizeType.ToInt();
  341. }
  342. var JsonData = new
  343. {
  344. authorizeType = authorizeType,
  345. authorizeData = existAuthorizeData,
  346. treeJson = treeList.TreeToJson(),
  347. };
  348. return Content(JsonData.ToJson());
  349. }
  350. #endregion
  351. #region 提交数据
  352. /// <summary>
  353. /// 保存角色成员
  354. /// </summary>
  355. /// <param name="roleId">角色Id</param>
  356. /// <param name="userIds">成员Id</param>
  357. /// <returns></returns>
  358. [HttpPost]
  359. [ValidateAntiForgeryToken]
  360. [AjaxOnly]
  361. public ActionResult SaveMember(string roleId, string userIds)
  362. {
  363. permissionBLL.SaveMember(AuthorizeTypeEnum.Role, roleId, userIds);
  364. return Success("保存成功。");
  365. }
  366. /// <summary>
  367. /// 保存角色授权
  368. /// </summary>
  369. /// <param name="roleId">角色Id</param>
  370. /// <param name="moduleIds">功能Id</param>
  371. /// <param name="moduleButtonIds">按钮Id</param>
  372. /// <param name="moduleColumnIds">视图Id</param>
  373. /// <param name="authorizeDataJson">数据权限</param>
  374. /// <returns></returns>
  375. [HttpPost]
  376. [ValidateAntiForgeryToken]
  377. [AjaxOnly]
  378. public ActionResult SaveAuthorize(string roleId, string moduleIds, string moduleButtonIds, string moduleColumnIds, string authorizeDataJson)
  379. {
  380. permissionBLL.SaveAuthorize(AuthorizeTypeEnum.Role, roleId, moduleIds, moduleButtonIds, moduleColumnIds, authorizeDataJson);
  381. return Success("保存成功。");
  382. }
  383. #endregion
  384. }
  385. }