You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
DSWMS/Vue.Net/VOL.Core/Infrastructure/DictionaryHandler.cs

126 lines
5.2 KiB
C#

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

using Microsoft.AspNetCore.Http;
using System;
using System.Collections.Generic;
using System.Text;
using VOL.Core.Const;
using VOL.Core.Enums;
using VOL.Core.ManageUser;
using VOL.Core.UserManager;
namespace VOL.Core.Infrastructure
{
public static class DictionaryHandler
{
/*2020.05.01增加根据用户信息加载字典数据源sql*/
/// <summary>
/// 获取自定义数据源sql
/// </summary>
/// <param name="dicNo"></param>
/// <param name="originalSql"></param>
/// <returns></returns>
public static string GetCustomDBSql(string dicNo, string originalSql,string CompanyField)
{
switch (dicNo)
{
case "roles":
originalSql = GetRolesSql(originalSql);
break;
//2020.05.24增加绑定table表时获取所有的角色列表
//注意如果是2020.05.24之前获取的数据库脚本
//请在菜单【下拉框绑定设置】添加一个字典编号【t_roles】,除了字典编号,其他内容随便填写
case "t_roles":
originalSql = GetRolesSql();
break;
case "company":
if (string.IsNullOrEmpty(CompanyField))
return originalSql;
break;
default:
break;
}
var curruserinfo = UserContext.Current.UserInfo;
if ( (CompanyField != "" && !string.IsNullOrWhiteSpace(originalSql))|| (!string.IsNullOrWhiteSpace(originalSql)&&(originalSql.IndexOf("##useridfield") >= 0 || originalSql.IndexOf("##companyfield") >= 0 || originalSql.IndexOf("##STOREHOUSEField") >= 0)) )
{
originalSql = originalSql.Replace(Convert.ToChar(10), ' ');
var corpid = curruserinfo.CompanyId;
if (curruserinfo.LimitInCompany)
originalSql = originalSql.Replace("##companyfield", CompanyField)
.Replace("##companyvalue", corpid);
else
originalSql = originalSql.Replace("##companyfield", "'1'")
.Replace("##companyvalue", "1");
if (curruserinfo.LimitInCompany)
{
originalSql = originalSql.Replace("##useridfield", "USERID")
.Replace("##useridvalue", curruserinfo.User_Id.ToString());
}
else
originalSql = originalSql.Replace("##useridfield", "'1'")
.Replace("##useridvalue", "1");
if (curruserinfo.LimitBySTORAGE)
{
originalSql = originalSql.Replace("##STOREHOUSEfield", "STOREHOUSE")
.Replace("##STOREHOUSEvalue", $"select AREACODE from OP_WMS_STOREHOUSE where id in (select pid from OP_WMS_STOREHOUSE_USERLIMIT where userid = '{curruserinfo.User_Id}')");
}
else
originalSql = originalSql.Replace("##STOREHOUSEfield", "'1'")
.Replace("##STOREHOUSEvalue", "'1'");
}
if (!string.IsNullOrWhiteSpace( originalSql) && (originalSql.IndexOf("##useridfield") > 0 || originalSql.IndexOf("##useridvalue") > 0)) {
if (originalSql.IndexOf("##useridfield") > 0)
originalSql = originalSql.Replace("##useridfield", "USERID");
if (originalSql.IndexOf("##useridvalue") > 0)
originalSql = originalSql.Replace("##useridvalue", $"{curruserinfo.User_Id}");
}
return originalSql;
}
/// <summary>
/// 2020.05.24增加绑定table表时获取所有的角色列表
/// </summary>
/// <param name="context"></param>
/// <param name="originalSql"></param>
/// <returns></returns>
public static string GetRolesSql()
{
if (DBType.Name == DbCurrentType.PgSql.ToString())
{
return "SELECT \"Role_Id\" as key,\"RoleName\" as value from Sys_Role_Core";
}
return $@"SELECT Role_Id as 'key',RoleName as 'value' FROM Sys_Role_Core
WHERE Enable=1 ";
}
/// <summary>
/// 获取解决的数据源,只能看到自己与下级所有角色
/// </summary>
/// <param name="context"></param>
/// <param name="originalSql"></param>
/// <returns></returns>
public static string GetRolesSql(string originalSql)
{
if (UserContext.Current.IsSuperAdmin)
{
return originalSql;
}
string currnetRoleId = UserContext.Current.RoleId;
List<string> roleIds = RoleContext.GetAllChildrenIds(currnetRoleId);
roleIds.Add(currnetRoleId);
string sql = $@"SELECT Role_Id as 'key',RoleName as 'value' FROM Sys_Role_Core
WHERE Enable=1 and Role_Id in ('{string.Join("','", roleIds)}')";
return sql;
}
}
}