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
|
{
|
public static class RoleSqlFunc
|
{
|
/// <summary>
|
/// 搜索(表)
|
/// </summary>
|
/// <param name="keyValue"></param>
|
/// <param name="page"></param>
|
/// <returns></returns>
|
public static List<SYS_ROLE> Search(RoleWebEntity webEntity, int page,int onePageNum, out string msg)
|
{
|
msg = "";
|
using (Model edm = new Model())
|
{
|
var f = PredicateBuilder.True<SYS_ROLE>();
|
//便利所有属性
|
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 (i.PropertyType == typeof(DateTime?))
|
{
|
if (v != null)
|
{
|
DateTime value = DateTime.Parse(v.ToString());
|
if (i.Name == "updateTimeStart")
|
{
|
f = f.And(x => x.UPDATETIME > value);
|
}
|
if (i.Name == "updateTimeEnd")
|
{
|
f = f.And(x => x.UPDATETIME < value);
|
}
|
}
|
}
|
else
|
{
|
if (v != null)
|
{
|
f = f.And(x => Object.Equals(Helper.Helper.GetFieldValueByName(x, i.Name), v));
|
}
|
}
|
}
|
|
List<SYS_ROLE> list = edm.SYS_ROLE.Where(f.Compile()).Skip((page - 1) * onePageNum).Take(onePageNum).ToList();
|
|
return list;
|
}
|
}
|
|
/// <summary>
|
/// 搜索(视图)
|
/// </summary>
|
/// <param name="keyValue"></param>
|
/// <param name="page"></param>
|
/// <returns></returns>
|
public static List<View_SYS_ROLE> SearchView(RoleWebEntity webEntity, int page, int onePageNum, out string msg)
|
{
|
msg = "";
|
using (Model edm = new Model())
|
{
|
var f = PredicateBuilder.True<View_SYS_ROLE>();
|
//便利所有属性
|
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 (i.PropertyType == typeof(DateTime?))
|
{
|
if (v != null)
|
{
|
DateTime value = DateTime.Parse(v.ToString());
|
if (i.Name == "updateTimeStart")
|
{
|
f = f.And(x => x.updateTime > value);
|
}
|
if (i.Name == "updateTimeEnd")
|
{
|
f = f.And(x => x.updateTime < value);
|
}
|
}
|
}
|
else
|
{
|
if (v != null)
|
{
|
f = f.And(x => Object.Equals(Helper.Helper.GetFieldValueByName(x, i.Name), v));
|
}
|
}
|
}
|
|
List<View_SYS_ROLE> list = edm.View_SYS_ROLE.Where(f.Compile()).Skip((page - 1) * onePageNum).Take(onePageNum).ToList();
|
|
return list;
|
}
|
}
|
|
/// <summary>
|
/// 搜索(视图)
|
/// </summary>
|
/// <param name="keyValue"></param>
|
/// <param name="page"></param>
|
/// <returns></returns>
|
public static int SearchViewNum(RoleWebEntity webEntity)
|
{
|
using (Model edm = new Model())
|
{
|
var f = PredicateBuilder.True<View_SYS_ROLE>();
|
|
//便利所有属性
|
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_SYS_ROLE.Where(f.Compile()).Count();
|
|
return num;
|
}
|
}
|
|
|
/// <summary>
|
/// 添加权限
|
/// </summary>
|
/// <param name="role"></param>
|
/// <returns></returns>
|
public static bool AddOrUpdate(RoleWebEntity webRole, out string msg)
|
{
|
msg = "";
|
using (Model edm = new Model())
|
{
|
Dictionary<string, string> dic = new Dictionary<string, string>();
|
//查询是否已存在此权限
|
SYS_ROLE role = edm.SYS_ROLE.FirstOrDefault(x => x.ROLENAME == webRole.roleName);
|
if (role == null)
|
{
|
//无此角色,属于新建
|
role = new SYS_ROLE();
|
}
|
role.ROLENAME= webRole.roleName??role.ROLENAME;
|
role.ENABLE= webRole.enable?? role.ENABLE;
|
SYS_USER user = edm.SYS_USER.FirstOrDefault(x => x.USERNAME == webRole.userName);
|
if (user != null)
|
{
|
role.CREATORID = user.ID;
|
|
}
|
else
|
{
|
role.CREATORID = 1;
|
}
|
role.UPDATETIME = DateTime.Now;
|
edm.SYS_ROLE.AddOrUpdateExtension(role);
|
if (edm.SaveChanges() > 0)
|
{
|
return true;
|
}
|
else
|
{
|
msg = "修改失败";
|
return false;
|
}
|
}
|
}
|
|
/// <summary>
|
/// 删除权限
|
/// </summary>
|
/// <param name="webUser"></param>
|
/// <returns></returns>
|
public static bool Delete(RoleWebEntity webRole,out string msg)
|
{
|
msg = "";
|
using (Model edm = new Model())
|
{
|
Dictionary<string, string> dic = new Dictionary<string, string>();
|
//查询是否已存在此权限
|
SYS_ROLE role = edm.SYS_ROLE.FirstOrDefault(x => x.ROLENAME == webRole.roleName);
|
if (role == null)
|
{
|
//无此角色
|
msg = "无此角色";
|
return false;
|
}
|
else
|
{
|
return DeleteRoleRelevance(role,out msg);
|
}
|
}
|
}
|
|
|
/// <summary>
|
/// 关联删除
|
/// </summary>
|
/// <param name="user"></param>
|
/// <returns></returns>
|
public static bool DeleteRoleRelevance(SYS_ROLE role,out string msg)
|
{
|
msg = "";
|
using (Model edm = new Model())
|
{
|
//因已释放连接,故重新指向数据库对象进行索引
|
SYS_ROLE roleDelete = edm.SYS_ROLE.FirstOrDefault(x => x.ROLENAME == role.ROLENAME);
|
////删除角色关系
|
//edm.SYS_USER_VS_ROLE.RemoveRange(roleDelete.SYS_USER_VS_ROLE);
|
//edm.SYS_ROLE_VS_PERMISSION.RemoveRange(roleDelete.SYS_ROLE_VS_PERMISSION);
|
//删除角色
|
//edm.SYS_ROLE.Remove(roleDelete);
|
roleDelete.ENABLE = 0;
|
if (edm.SaveChanges() > 0)
|
{
|
return true;
|
}
|
else
|
{
|
msg = "删除失败";
|
return false;
|
}
|
}
|
}
|
}
|
}
|