using IWareDataAccess.EF; using IWareDataAccess.Entity.Sys; using IWareDataAccess.Helper; using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace IWareDataAccess.Sys.ROLE_VS_PERMISSION { public static class Role_Vs_PermissionSqlFunc { /// /// 搜索视图 /// /// /// public static List SearchView(PermissionVsRoleWebEntity webEntity,out string msg) { msg = ""; using (Model edm = new Model()) { var f = PredicateBuilder.True(); //便利所有属性 Type type = webEntity.GetType(); foreach (var i in type.GetProperties()) { object v = Helper.Helper.GetFieldValueByName(webEntity, i.Name); if (i.PropertyType == typeof(String)) { string value; if (v != null) { value = v.ToString(); f = f.And(x => Helper.Helper.GetFieldValueByName(x, i.Name) != null ? Helper.Helper.GetFieldValueByName(x, i.Name).ToString().Contains(value) : false); } } else { if (v != null) { f = f.And(x => Object.Equals(Helper.Helper.GetFieldValueByName(x, i.Name), v)); } } } List list = edm.View_ROLE_VS_PERMISSION.Where(f.Compile()).ToList(); return list; } } /// /// 搜索视图 /// /// /// public static int SearchViewNum(PermissionVsRoleWebEntity webEntity) { using (Model edm = new Model()) { var f = PredicateBuilder.True(); //便利所有属性 Type type = webEntity.GetType(); foreach (var i in type.GetProperties()) { object v = Helper.Helper.GetFieldValueByName(webEntity, i.Name); if (i.PropertyType == typeof(String)) { string value; if (v != null) { value = v.ToString(); f = f.And(x => Helper.Helper.GetFieldValueByName(x, i.Name) != null ? Helper.Helper.GetFieldValueByName(x, i.Name).ToString().Contains(value) : false); } } else { if (v != null) { f = f.And(x => Object.Equals(Helper.Helper.GetFieldValueByName(x, i.Name), v)); } } } int num = edm.View_ROLE_VS_PERMISSION.Where(f.Compile()).Count(); return num; } } /// /// 添加权限 /// /// /// public static bool AddOrUpdate(PermissionVsRoleWebEntity webRoleVsPermission,out string msg) { msg = ""; using (Model edm = new Model()) { RoleWebEntity searchEntity = new RoleWebEntity(); //查询是否存在此角色 SYS_ROLE role = edm.SYS_ROLE.FirstOrDefault(x => x.ROLENAME == webRoleVsPermission.roleName); if (role == null) { //无此角色 msg = "无此角色"; return false; } int type = 1; if (webRoleVsPermission.permissionNameList != null && webRoleVsPermission.permissionNameList.Count > 0) { int id = webRoleVsPermission.permissionNameList[0]; type=(int)edm.SYS_PERMISSION.FirstOrDefault(x=>x.ID==id).TYPE; } else { msg = "获取该角色的权限失败!"; return false; } if (DeleteAll(webRoleVsPermission.roleName, type, out msg)) { foreach (var i in webRoleVsPermission.permissionNameList) { //如果输入权限包含遍历的权限,添加 SYS_ROLE_VS_PERMISSION rvp = new SYS_ROLE_VS_PERMISSION(); rvp.PERMISSIONID = i; rvp.ROLEID = role.ID; edm.SYS_ROLE_VS_PERMISSION.AddOrUpdateExtension(rvp); } } else { msg = "保存失败!"; return false; } if (edm.SaveChanges() > 0) { return true; } else { msg = "修改失败"; return false; } } } /// /// 初始化角色权限 /// /// /// public static bool DeleteAll(string roleName,int type,out string msg) { try { msg = ""; using (Model edm = new Model()) { List rvplst = new List(); var list = edm.SYS_ROLE_VS_PERMISSION.Where(x => x.SYS_ROLE.ROLENAME == roleName); var plst = edm.SYS_PERMISSION.Where(x => x.TYPE == type).ToList(); plst.ForEach(x => { var rvp = list.FirstOrDefault(y => y.PERMISSIONID == x.ID); if (rvp != null) { rvplst.Add(rvp); } }); edm.SYS_ROLE_VS_PERMISSION.RemoveRange(rvplst); edm.SaveChanges(); return true; } } catch (Exception ex) { msg = "保存失败"; return false; } } } }