😎增加种子执行排序特性及实现
This commit is contained in:
parent
1b2486fa35
commit
6744c5471a
@ -32,7 +32,7 @@
|
|||||||
"CorsAccessorSettings": {
|
"CorsAccessorSettings": {
|
||||||
//"PolicyName": "App.Cors.Policy",
|
//"PolicyName": "App.Cors.Policy",
|
||||||
//"WithOrigins": [ "http://localhost:5005", "https://gitee.com" ],
|
//"WithOrigins": [ "http://localhost:5005", "https://gitee.com" ],
|
||||||
"WithExposedHeaders": [ "Content-Disposition", "X-Pagination", "access-token", "x-access-token" ], // 如果前端不代理且是axios请求
|
"WithExposedHeaders": [ "Content-Disposition", "X-Pagination", "access-token", "x-access-token", "Access-Control-Expose-Headersx-access-token" ], // 如果前端不代理且是axios请求
|
||||||
"SignalRSupport": true // 启用 SignalR 跨域支持
|
"SignalRSupport": true // 启用 SignalR 跨域支持
|
||||||
},
|
},
|
||||||
"SnowId": {
|
"SnowId": {
|
||||||
|
|||||||
25
Admin.NET/Admin.NET.Core/Attribute/SeedDataAttribute.cs
Normal file
25
Admin.NET/Admin.NET.Core/Attribute/SeedDataAttribute.cs
Normal file
@ -0,0 +1,25 @@
|
|||||||
|
// Admin.NET 项目的版权、商标、专利和其他相关权利均受相应法律法规的保护。使用本项目应遵守相关法律法规和许可证的要求。
|
||||||
|
//
|
||||||
|
// 本项目主要遵循 MIT 许可证和 Apache 许可证(版本 2.0)进行分发和使用。许可证位于源代码树根目录中的 LICENSE-MIT 和 LICENSE-APACHE 文件。
|
||||||
|
//
|
||||||
|
// 不得利用本项目从事危害国家安全、扰乱社会秩序、侵犯他人合法权益等法律法规禁止的活动!任何基于本项目二次开发而产生的一切法律纠纷和责任,我们不承担任何责任!
|
||||||
|
|
||||||
|
namespace Admin.NET.Core;
|
||||||
|
|
||||||
|
/// <summary>
|
||||||
|
/// 种子数据特性
|
||||||
|
/// </summary>
|
||||||
|
[SuppressSniffer]
|
||||||
|
[AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = true)]
|
||||||
|
public class SeedDataAttribute : Attribute
|
||||||
|
{
|
||||||
|
/// <summary>
|
||||||
|
/// 排序(越大越后执行)
|
||||||
|
/// </summary>
|
||||||
|
public int Order { get; set; } = 0;
|
||||||
|
|
||||||
|
public SeedDataAttribute(int orderNo)
|
||||||
|
{
|
||||||
|
Order = orderNo;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -323,7 +323,8 @@ public static class SqlSugarSetup
|
|||||||
if (config.SeedSettings.EnableInitSeed)
|
if (config.SeedSettings.EnableInitSeed)
|
||||||
{
|
{
|
||||||
var seedDataTypes = App.EffectiveTypes.Where(u => !u.IsInterface && !u.IsAbstract && u.IsClass && u.GetInterfaces().Any(i => i.HasImplementedRawGeneric(typeof(ISqlSugarEntitySeedData<>))))
|
var seedDataTypes = App.EffectiveTypes.Where(u => !u.IsInterface && !u.IsAbstract && u.IsClass && u.GetInterfaces().Any(i => i.HasImplementedRawGeneric(typeof(ISqlSugarEntitySeedData<>))))
|
||||||
.WhereIF(config.SeedSettings.EnableIncreSeed, u => u.IsDefined(typeof(IncreSeedAttribute), false)).ToList();
|
.WhereIF(config.SeedSettings.EnableIncreSeed, u => u.IsDefined(typeof(IncreSeedAttribute), false))
|
||||||
|
.OrderBy(u => u.GetCustomAttributes(typeof(SeedDataAttribute), false).Length > 0 ? (u.GetCustomAttributes(typeof(SeedDataAttribute), false)[0] as SeedDataAttribute).Order : 0).ToList();
|
||||||
|
|
||||||
foreach (var seedType in seedDataTypes)
|
foreach (var seedType in seedDataTypes)
|
||||||
{
|
{
|
||||||
@ -400,7 +401,8 @@ public static class SqlSugarSetup
|
|||||||
|
|
||||||
// 初始化业务应用种子数据
|
// 初始化业务应用种子数据
|
||||||
var seedDataTypes = App.EffectiveTypes.Where(u => !u.IsInterface && !u.IsAbstract && u.IsClass && u.GetInterfaces().Any(i => i.HasImplementedRawGeneric(typeof(ISqlSugarEntitySeedData<>))))
|
var seedDataTypes = App.EffectiveTypes.Where(u => !u.IsInterface && !u.IsAbstract && u.IsClass && u.GetInterfaces().Any(i => i.HasImplementedRawGeneric(typeof(ISqlSugarEntitySeedData<>))))
|
||||||
.Where(u => u.IsDefined(typeof(AppSeedAttribute), false)).ToList();
|
.Where(u => u.IsDefined(typeof(AppSeedAttribute), false))
|
||||||
|
.OrderBy(u => u.GetCustomAttributes(typeof(SeedDataAttribute), false).Length > 0 ? (u.GetCustomAttributes(typeof(SeedDataAttribute), false)[0] as SeedDataAttribute).Order : 0).ToList();
|
||||||
|
|
||||||
foreach (var seedType in seedDataTypes)
|
foreach (var seedType in seedDataTypes)
|
||||||
{
|
{
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user