PermissionPostController.cs 15 KB

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