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;
            }
        }
    }
}