public JsonResult GetRolePermission(int id) { IRelationRoleModuleService relationRoleModuleService = ServiceFactory.Create <IRelationRoleModuleService>(); List <int> moduleIDs = relationRoleModuleService.GetEntities(t => t.RoleID == id).Select(t => t.ModuleID).ToList(); return(Json(moduleIDs, JsonRequestBehavior.AllowGet)); }
private bool AddRelationRoleModule(string IDs, string ModuleIDs, int createUserID = 0) { if (string.IsNullOrWhiteSpace(IDs) || string.IsNullOrWhiteSpace(ModuleIDs)) { return(false); } if (createUserID == 0) { createUserID = CurrentInfo.CurrentUser.ID; } List <int> roleIDArr = IDs.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries).Select(t => Convert.ToInt32(t)).ToList(); List <int> moduleArr = ModuleIDs.Split(new char[] { ',' }, StringSplitOptions.RemoveEmptyEntries).Select(t => Convert.ToInt32(t)).ToList(); //把所有菜单的父菜单取出来,但是只能保证三级菜单,多级有可能有bug IModuleService moduleService = ServiceFactory.Create <IModuleService>(); List <Module> allListModule = new List <Module>(); allListModule.AddRange(moduleService.GetEntities(t => moduleArr.Contains(t.ID)).ToList()); //foreach (var item in allListModule) //{ // Module parentModule = moduleService.GetFirstOrDefault(t => t.ID == item.ParentID); // if (parentModule != null) // { // if (allListModule.Where(t => t.ID == parentModule.ID).Count() == 0) // { // allListModule.Add(parentModule); // } // } //} for (int i = 0; i < allListModule.Count(); i++) { int parentID = allListModule[i].ParentID; Module parentModule = moduleService.GetFirstOrDefault(t => t.ID == parentID); if (parentModule != null) { if (allListModule.Where(t => t.ID == parentModule.ID).Count() == 0) { allListModule.Add(parentModule); } } } //从新生成菜单ID moduleArr = allListModule.Select(t => t.ID).ToList(); IRelationRoleModuleService relationRoleModuleService = ServiceFactory.Create <IRelationRoleModuleService>(); List <RelationRoleModule> listRelationRolesModule = new List <RelationRoleModule>(); int addCount = 0; using (TransactionScope scope = TransactionScopeHelper.GetTran()) { foreach (var roleID in roleIDArr) { //删除当前人员的所有的权限,然后在添加新的权限 var roleModule = relationRoleModuleService.GetEntities(t => t.RoleID == roleID); relationRoleModuleService.DeleteEntities(roleModule.ToList()); foreach (var moduleID in moduleArr) { RelationRoleModule model = new RelationRoleModule(); model.RoleID = roleID; model.ModuleID = moduleID; model.CreateUserID = createUserID; model.CreateTime = DateTime.Now; listRelationRolesModule.Add(model); } } addCount = relationRoleModuleService.AddEntities(listRelationRolesModule).Count(); scope.Complete(); } if (addCount > 0) { return(true); } else { return(false); } }