dengjunjie
2025-07-09 7ca9651f81d7b84f054194d3d46fdbd1d9c8b922
ÏîÄ¿´úÂë/WMS/WIDESEA_WMSServer/WIDESEA_Core/DB/RepositorySetting.cs
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,53 @@
using SqlSugar;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection;
using System.Text;
using System.Threading.Tasks;
using WIDESEA_Core.DB.Models;
using WIDESEA_Core.Tenants;
namespace WIDESEA_Core.DB
{
    public class RepositorySetting
    {
        private static readonly Lazy<IEnumerable<Type>> AllEntitys = new(() =>
        {
            var path = AppDomain.CurrentDomain.RelativeSearchPath ?? AppDomain.CurrentDomain.BaseDirectory;
            var referencedAssemblies = System.IO.Directory.GetFiles(path, MainDb.AssemblyName).Select(Assembly.LoadFrom).FirstOrDefault();
            return referencedAssemblies
                .GetTypes()
                .Where(t => t.IsClass && !t.IsAbstract && t.IsSubclassOf(typeof(BaseEntity)))
                .Where(it => it.FullName != null && it.FullName.StartsWith(MainDb.EntityNameSpace));
        });
        public static IEnumerable<Type> Entitys => AllEntitys.Value;
        /// <summary>
        /// é…ç½®å®žä½“软删除过滤器<br/>
        /// ç»Ÿä¸€è¿‡æ»¤ è½¯åˆ é™¤ æ— éœ€è‡ªå·±å†™æ¡ä»¶
        /// </summary>
        public static void SetDeletedEntityFilter(SqlSugarScopeProvider db)
        {
            //db.QueryFilter.AddTableFilter<IDeleteFilter>(it => it.IsDeleted == false);
        }
        /// <summary>
        /// é…ç½®ç§Ÿæˆ·
        /// </summary>
        public static void SetTenantEntityFilter(SqlSugarScopeProvider db)
        {
            if (App.User is not { UserId: > 0, TenantId: > 0 })
            {
                return;
            }
            //多租户 å•表
            //db.QueryFilter.AddTableFilter<ITenantEntity>(it => it.TenantId == App.User.TenantId || it.TenantId == 0);
            //多租户 å¤šè¡¨
            //db.SetTenantTable(App.User.TenantId.ToString());
        }
    }
}