Initial_commit_SecMPS_v2

This commit is contained in:
2026-05-15 23:22:48 +08:00
commit 23ea4fe05f
13830 changed files with 298675 additions and 0 deletions

View File

@@ -0,0 +1,162 @@
using Microsoft.AspNetCore.Http;
using System;
using System.Collections.Generic;
using System.Text;
using VolPro.Core.Configuration;
using VolPro.Core.Const;
using VolPro.Core.Enums;
using VolPro.Core.ManageUser;
using VolPro.Core.UserManager;
namespace VolPro.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)
{
switch (dicNo)
{
case "部门级联":
originalSql = GetDeptSql(originalSql);
break;
case "岗位":
originalSql = GetPostSql(originalSql);
break;
//2020.05.24增加绑定table表时获取所有的角色列表
//注意如果是2020.05.24之前获取的数据库脚本
//请在菜单【下拉框绑定设置】添加一个字典编号【t_roles】,除了字典编号,其他内容随便填写
case "roles":
case "t_roles":
case "tree_roles":
originalSql = GetRolesSql(originalSql);
break;
case "集团":
if (IsPgSql)
{
originalSql = "SELECT \"GroupId\" AS key,\"GroupName\" AS value FROM PUBLIC.\"Sys_Group\"";
}
break;
default:
break;
}
return originalSql;
}
private static bool IsPgSql
{
get { return DBType.Name == DbCurrentType.PgSql.ToString()|| DBType.Name == DbCurrentType.Kdbndp.ToString(); }
}
private static bool IsOracle
{
get { return DBType.Name == DbCurrentType.Oracle.ToString(); }
}
/// <summary>
/// 获取解决的数据源,只能看到自己与下级所有角色
/// </summary>
/// <param name="context"></param>
/// <param name="originalSql"></param>
/// <returns></returns>
public static string GetRolesSql(string originalSql)
{
if (IsPgSql)
{
return GetRolesPgSql(originalSql);
}
originalSql = "SELECT Role_Id AS id,parentId,Role_Id AS 'key',RoleName AS value FROM Sys_Role where 1=1 ";
if (UserContext.Current.IsSuperAdmin)
{
return originalSql;
}
var roleIds = UserContext.Current.GetAllChildrenRoleIds();
string sql = $@" {originalSql} and Role_Id in ({string.Join(',', roleIds)})";
return sql;
}
/// <summary>
/// 岗位数据源
/// </summary>
/// <param name="originalSql"></param>
/// <returns></returns>
public static string GetPostSql(string originalSql)
{
if ((DBType.Name == "MySql" || DBType.Name == "MsSql") && AppSetting.UseDynamicShareDB)
{
originalSql = $"SELECT PostId AS id,PostId AS 'key',ParentId AS parentId,PostName AS 'value' FROM Sys_Post where DbServiceId='{UserContext.CurrentServiceId}'";
}
//其他数据库自己完善下
return originalSql;
}
public static string GetRolesPgSql(string originalSql)
{
originalSql = "SELECT \"Role_Id\" AS id,\"ParentId\" as \"parentId\",\"Role_Id\" AS key,\"RoleName\" AS value FROM \"public\".\"Sys_Role\" where 1=1 ";
if (UserContext.Current.IsSuperAdmin)
{
return originalSql;
}
var roleIds = UserContext.Current.GetAllChildrenRoleIds();
string sql = $" {originalSql} and \"Role_Id\" in ({string.Join(',', roleIds)})";
return sql;
}
/// <summary>
/// 部门数据源
/// </summary>
/// <param name="originalSql"></param>
/// <returns></returns>
public static string GetDeptSql(string originalSql)
{
if (IsPgSql)
{
originalSql = "SELECT \"DepartmentId\" AS id,\"DepartmentId\" AS key,\"ParentId\" AS parentId,\"DepartmentName\" AS value FROM PUBLIC.\"Sys_Department\" ";
}
else if (IsOracle)
{
originalSql = "SELECT DEPARTMENTID AS \"id\",DEPARTMENTID AS \"key\",PARENTID as \"parentId\",DEPARTMENTNAME as \"value\" FROM SYS_DEPARTMENT ";
}
else
{
originalSql = "SELECT DepartmentId AS id,DepartmentId AS 'key',ParentId AS parentId,DepartmentName AS value FROM Sys_Department";
}
if (UserContext.Current.IsSuperAdmin)
{
return originalSql;
}
var deptIds = UserContext.Current.DeptIds;
deptIds = DepartmentContext.GetAllChildrenIds(deptIds);
switch (DBType.Name)
{
//mysql如果端口不是3306这里也需要修改
case "MySql":
originalSql = $@"{originalSql}
WHERE DepartmentId in ('{string.Join("','", deptIds)}')";
break;
case "PgSql":
originalSql = $"{originalSql} WHERE \"DepartmentId\" in ('{string.Join("','", deptIds)}')";
break;
case "MsSql":
originalSql = $@"{originalSql}
WHERE DepartmentId in ('{string.Join("','", deptIds)}')";
break;
case "Oracle":
originalSql = $@"{originalSql}
WHERE DEPARTMENTID in ('{string.Join("','", deptIds)}')";
break;
}
return originalSql;
}
}
}