diff --git a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/AbpDbContext.cs b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/AbpDbContext.cs index cda8c02416..22f04542f1 100644 --- a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/AbpDbContext.cs +++ b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/AbpDbContext.cs @@ -86,7 +86,6 @@ namespace Volo.Abp.EntityFrameworkCore protected AbpDbContext(DbContextOptions options) : base(options) { - } protected override void OnModelCreating(ModelBuilder modelBuilder) diff --git a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/Modeling/AbpEntityTypeBuilderExtensions.cs b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/Modeling/AbpEntityTypeBuilderExtensions.cs index a40c4d6254..44cad9c638 100644 --- a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/Modeling/AbpEntityTypeBuilderExtensions.cs +++ b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/Modeling/AbpEntityTypeBuilderExtensions.cs @@ -82,6 +82,11 @@ namespace Volo.Abp.EntityFrameworkCore.Modeling } } + public static void ApplyObjectExtensionMappings(this EntityTypeBuilder b) + { + ObjectExtensionManager.Instance.ConfigureEfCoreEntity(b); + } + public static void ConfigureSoftDelete(this EntityTypeBuilder b) where T : class, ISoftDelete { diff --git a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/Modeling/AbpModelBuilderObjectExtensions.cs b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/Modeling/AbpModelBuilderObjectExtensions.cs new file mode 100644 index 0000000000..295f6ef7cf --- /dev/null +++ b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/EntityFrameworkCore/Modeling/AbpModelBuilderObjectExtensions.cs @@ -0,0 +1,14 @@ +using Microsoft.EntityFrameworkCore; +using Volo.Abp.ObjectExtending; + +namespace Volo.Abp.EntityFrameworkCore.Modeling +{ + public static class AbpModelBuilderObjectExtensions + { + public static void TryConfigureObjectExtensions(this ModelBuilder modelBuilder) + where TDbContext : DbContext + { + ObjectExtensionManager.Instance.ConfigureEfCoreDbContext(modelBuilder); + } + } +} diff --git a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/EfCoreObjectExtensionInfoExtensions.cs b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/EfCoreObjectExtensionInfoExtensions.cs index 17b495cdad..f27fc12d64 100644 --- a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/EfCoreObjectExtensionInfoExtensions.cs +++ b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/EfCoreObjectExtensionInfoExtensions.cs @@ -1,11 +1,17 @@ using System; +using System.Collections.Generic; +using System.Linq; using JetBrains.Annotations; +using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Metadata.Builders; namespace Volo.Abp.ObjectExtending { public static class EfCoreObjectExtensionInfoExtensions { + public const string EfCoreDbContextConfigurationName = "EfCoreDbContextMapping"; + public const string EfCoreEntityConfigurationName = "EfCoreEntityMapping"; + [Obsolete("Use MapEfCoreProperty with EntityTypeAndPropertyBuildAction parameters.")] public static ObjectExtensionInfo MapEfCoreProperty( [NotNull] this ObjectExtensionInfo objectExtensionInfo, @@ -71,5 +77,69 @@ namespace Volo.Abp.ObjectExtending } ); } + + public static ObjectExtensionInfo MapEfCoreEntity( + [NotNull] this ObjectExtensionInfo objectExtensionInfo, + [NotNull] Action entityTypeBuildAction) + { + Check.NotNull(objectExtensionInfo, nameof(objectExtensionInfo)); + + var mappingOptionList = new List + { + new ObjectExtensionInfoEfCoreMappingOptions( + objectExtensionInfo, + entityTypeBuildAction) + }; + + objectExtensionInfo.Configuration.AddOrUpdate(EfCoreEntityConfigurationName, mappingOptionList, + (k, v) => + { + v.As>().Add(mappingOptionList.First()); + return v; + }); + + return objectExtensionInfo; + } + + public static ObjectExtensionInfo MapEfCoreDbContext( + [NotNull] this ObjectExtensionInfo objectExtensionInfo, + [NotNull] Action modelBuildAction) + { + Check.NotNull(objectExtensionInfo, nameof(objectExtensionInfo)); + + var mappingOptionList = new List + { + new ObjectExtensionInfoEfCoreMappingOptions( + objectExtensionInfo, + modelBuildAction) + }; + + objectExtensionInfo.Configuration.AddOrUpdate(EfCoreDbContextConfigurationName, mappingOptionList, + (k, v) => + { + v.As>().Add(mappingOptionList.First()); + return v; + }); + + return objectExtensionInfo; + } + + public static List GetEfCoreEntityMappings( + [NotNull] this ObjectExtensionInfo objectExtensionInfo) + { + Check.NotNull(objectExtensionInfo, nameof(objectExtensionInfo)); + + return !objectExtensionInfo.Configuration.TryGetValue(EfCoreEntityConfigurationName, out var options) ? + new List() : options.As>(); + } + + public static List GetEfCoreDbContextMappings( + [NotNull] this ObjectExtensionInfo objectExtensionInfo) + { + Check.NotNull(objectExtensionInfo, nameof(objectExtensionInfo)); + + return !objectExtensionInfo.Configuration.TryGetValue(EfCoreDbContextConfigurationName, out var options) ? + new List() : options.As>(); + } } } diff --git a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/EfCoreObjectExtensionManagerExtensions.cs b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/EfCoreObjectExtensionManagerExtensions.cs index 54c1909bb3..86d4115421 100644 --- a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/EfCoreObjectExtensionManagerExtensions.cs +++ b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/EfCoreObjectExtensionManagerExtensions.cs @@ -1,5 +1,6 @@ using System; using JetBrains.Annotations; +using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Metadata.Builders; using Volo.Abp.Data; using Volo.Abp.Domain.Entities; @@ -8,6 +9,45 @@ namespace Volo.Abp.ObjectExtending { public static class EfCoreObjectExtensionManagerExtensions { + public static ObjectExtensionManager MapEfCoreDbContext( + [NotNull] this ObjectExtensionManager objectExtensionManager, + [NotNull] Action modelBuilderAction) + where TDbContext : DbContext + { + return objectExtensionManager.AddOrUpdate( + typeof(TDbContext), + options => + { + options.MapEfCoreDbContext(modelBuilderAction); + }); + } + + public static ObjectExtensionManager MapEfCoreEntity( + [NotNull] this ObjectExtensionManager objectExtensionManager, + [NotNull] Action entityTypeBuildAction) + where TEntity : IEntity + { + return MapEfCoreEntity( + objectExtensionManager, + typeof(TEntity), + entityTypeBuildAction); + } + + public static ObjectExtensionManager MapEfCoreEntity( + [NotNull] this ObjectExtensionManager objectExtensionManager, + [NotNull] Type entityType, + [NotNull] Action entityTypeBuildAction) + { + Check.NotNull(objectExtensionManager, nameof(objectExtensionManager)); + + return objectExtensionManager.AddOrUpdate( + entityType, + options => + { + options.MapEfCoreEntity(entityTypeBuildAction); + }); + } + public static ObjectExtensionManager MapEfCoreProperty( [NotNull] this ObjectExtensionManager objectExtensionManager, [NotNull] string propertyName) @@ -32,10 +72,7 @@ namespace Volo.Abp.ObjectExtending entityType, propertyType, propertyName, - options => - { - options.MapEfCore(); - } + options => { options.MapEfCore(); } ); } @@ -126,6 +163,13 @@ namespace Volo.Abp.ObjectExtending return; } + var efCoreEntityMappings = objectExtension.GetEfCoreEntityMappings(); + + foreach (var efCoreEntityMapping in efCoreEntityMappings) + { + efCoreEntityMapping.EntityTypeBuildAction?.Invoke(typeBuilder); + } + foreach (var property in objectExtension.GetProperties()) { var efCoreMapping = property.GetEfCoreMappingOrNull(); @@ -148,5 +192,27 @@ namespace Volo.Abp.ObjectExtending #pragma warning restore 618 } } + + public static void ConfigureEfCoreDbContext( + [NotNull] this ObjectExtensionManager objectExtensionManager, + [NotNull] ModelBuilder modelBuilder) + where TDbContext : DbContext + { + Check.NotNull(objectExtensionManager, nameof(objectExtensionManager)); + Check.NotNull(modelBuilder, nameof(modelBuilder)); + + var objectExtension = objectExtensionManager.GetOrNull(typeof(TDbContext)); + if (objectExtension == null) + { + return; + } + + var efCoreDbContextMappings = objectExtension.GetEfCoreDbContextMappings(); + + foreach (var efCoreDbContextMapping in efCoreDbContextMappings) + { + efCoreDbContextMapping.ModelBuildAction?.Invoke(modelBuilder); + } + } } } diff --git a/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/ObjectExtensionInfoEfCoreMappingOptions.cs b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/ObjectExtensionInfoEfCoreMappingOptions.cs new file mode 100644 index 0000000000..5510e138e4 --- /dev/null +++ b/framework/src/Volo.Abp.EntityFrameworkCore/Volo/Abp/ObjectExtending/ObjectExtensionInfoEfCoreMappingOptions.cs @@ -0,0 +1,39 @@ +using System; +using JetBrains.Annotations; +using Microsoft.EntityFrameworkCore; +using Microsoft.EntityFrameworkCore.Metadata.Builders; + +namespace Volo.Abp.ObjectExtending +{ + public class ObjectExtensionInfoEfCoreMappingOptions + { + [NotNull] + public ObjectExtensionInfo ObjectExtension { get; } + + [CanBeNull] + public Action EntityTypeBuildAction { get; set; } + + [CanBeNull] + public Action ModelBuildAction { get; set; } + + public ObjectExtensionInfoEfCoreMappingOptions( + [NotNull] ObjectExtensionInfo objectExtension, + [NotNull] Action entityTypeBuildAction) + { + ObjectExtension = Check.NotNull(objectExtension, nameof(objectExtension)); + EntityTypeBuildAction = Check.NotNull(entityTypeBuildAction, nameof(entityTypeBuildAction)); + + EntityTypeBuildAction = entityTypeBuildAction; + } + + public ObjectExtensionInfoEfCoreMappingOptions( + [NotNull] ObjectExtensionInfo objectExtension, + [NotNull] Action modelBuildAction) + { + ObjectExtension = Check.NotNull(objectExtension, nameof(objectExtension)); + ModelBuildAction = Check.NotNull(modelBuildAction, nameof(modelBuildAction)); + + ModelBuildAction = modelBuildAction; + } + } +} diff --git a/framework/src/Volo.Abp.ObjectExtending/Volo/Abp/ObjectExtending/ObjectExtensionInfo.cs b/framework/src/Volo.Abp.ObjectExtending/Volo/Abp/ObjectExtending/ObjectExtensionInfo.cs index 237953db4a..7b71386474 100644 --- a/framework/src/Volo.Abp.ObjectExtending/Volo/Abp/ObjectExtending/ObjectExtensionInfo.cs +++ b/framework/src/Volo.Abp.ObjectExtending/Volo/Abp/ObjectExtending/ObjectExtensionInfo.cs @@ -24,7 +24,7 @@ namespace Volo.Abp.ObjectExtending public ObjectExtensionInfo([NotNull] Type type) { - Type = Check.AssignableTo(type, nameof(type)); + Type = Check.NotNull(type, nameof(type)); Properties = new ConcurrentDictionary(); Configuration = new ConcurrentDictionary(); Validators = new List>(); diff --git a/framework/src/Volo.Abp.ObjectExtending/Volo/Abp/ObjectExtending/ObjectExtensionManager.cs b/framework/src/Volo.Abp.ObjectExtending/Volo/Abp/ObjectExtending/ObjectExtensionManager.cs index 4cbc3a3fb8..85a60a2824 100644 --- a/framework/src/Volo.Abp.ObjectExtending/Volo/Abp/ObjectExtending/ObjectExtensionManager.cs +++ b/framework/src/Volo.Abp.ObjectExtending/Volo/Abp/ObjectExtending/ObjectExtensionManager.cs @@ -25,7 +25,6 @@ namespace Volo.Abp.ObjectExtending [NotNull] public virtual ObjectExtensionManager AddOrUpdate( [CanBeNull] Action configureAction = null) - where TObject : IHasExtraProperties { return AddOrUpdate(typeof(TObject), configureAction); } @@ -50,8 +49,6 @@ namespace Volo.Abp.ObjectExtending [NotNull] Type type, [CanBeNull] Action configureAction = null) { - Check.AssignableTo(type, nameof(type)); - var extensionInfo = ObjectsExtensions.GetOrAdd( type, _ => new ObjectExtensionInfo(type) @@ -64,7 +61,6 @@ namespace Volo.Abp.ObjectExtending [CanBeNull] public virtual ObjectExtensionInfo GetOrNull() - where TObject : IHasExtraProperties { return GetOrNull(typeof(TObject)); } @@ -72,8 +68,6 @@ namespace Volo.Abp.ObjectExtending [CanBeNull] public virtual ObjectExtensionInfo GetOrNull([NotNull] Type type) { - Check.AssignableTo(type, nameof(type)); - return ObjectsExtensions.GetOrDefault(type); } diff --git a/framework/test/Volo.Abp.EntityFrameworkCore.Tests/Volo/Abp/EntityFrameworkCore/Domain/TestEntityExtensionConfigurator.cs b/framework/test/Volo.Abp.EntityFrameworkCore.Tests/Volo/Abp/EntityFrameworkCore/Domain/TestEntityExtensionConfigurator.cs index 469dfbdfd4..a3b0004027 100644 --- a/framework/test/Volo.Abp.EntityFrameworkCore.Tests/Volo/Abp/EntityFrameworkCore/Domain/TestEntityExtensionConfigurator.cs +++ b/framework/test/Volo.Abp.EntityFrameworkCore.Tests/Volo/Abp/EntityFrameworkCore/Domain/TestEntityExtensionConfigurator.cs @@ -1,6 +1,8 @@ using System; +using Microsoft.EntityFrameworkCore.Metadata.Builders; using Volo.Abp.ObjectExtending; using Volo.Abp.TestApp.Domain; +using Volo.Abp.TestApp.EntityFrameworkCore; using Volo.Abp.Threading; namespace Volo.Abp.EntityFrameworkCore.Domain @@ -35,7 +37,31 @@ namespace Volo.Abp.EntityFrameworkCore.Domain "EnumNumberString" ).MapEfCoreProperty( "EnumLiteral" - ); + ).MapEfCoreEntity(b => + { + b.As>() + .Property(x=>x.Name).IsRequired(); + + }).MapEfCoreEntity(b => + { + b.As>() + .Property(x=>x.Name).HasMaxLength(200); + + }).MapEfCoreEntity(typeof(Person), b => + { + b.As>() + .HasIndex(x=>x.Birthday); + }); + + ObjectExtensionManager.Instance.MapEfCoreDbContext(b => + { + b.Entity().Property(x => x.Name).IsRequired(); + }); + + ObjectExtensionManager.Instance.MapEfCoreDbContext(b => + { + b.Entity().Property(x => x.Name).IsRequired(); + }); }); } } diff --git a/framework/test/Volo.Abp.EntityFrameworkCore.Tests/Volo/Abp/TestApp/EntityFrameworkCore/TestAppDbContext.cs b/framework/test/Volo.Abp.EntityFrameworkCore.Tests/Volo/Abp/TestApp/EntityFrameworkCore/TestAppDbContext.cs index cd8bb75b78..6263c116b8 100644 --- a/framework/test/Volo.Abp.EntityFrameworkCore.Tests/Volo/Abp/TestApp/EntityFrameworkCore/TestAppDbContext.cs +++ b/framework/test/Volo.Abp.EntityFrameworkCore.Tests/Volo/Abp/TestApp/EntityFrameworkCore/TestAppDbContext.cs @@ -1,6 +1,7 @@ using Microsoft.EntityFrameworkCore; using Volo.Abp.DependencyInjection; using Volo.Abp.EntityFrameworkCore; +using Volo.Abp.EntityFrameworkCore.Modeling; using Volo.Abp.EntityFrameworkCore.TestApp.FourthContext; using Volo.Abp.EntityFrameworkCore.TestApp.ThirdDbContext; using Volo.Abp.TestApp.Domain; @@ -41,6 +42,8 @@ namespace Volo.Abp.TestApp.EntityFrameworkCore modelBuilder.Entity(b => { b.HasKey(p => new {p.PersonId, p.Number}); + + b.ApplyObjectExtensionMappings(); }); modelBuilder @@ -48,6 +51,8 @@ namespace Volo.Abp.TestApp.EntityFrameworkCore { p.HasNoKey(); p.ToView("View_PersonView"); + + p.ApplyObjectExtensionMappings(); }); modelBuilder.Entity(b => @@ -57,7 +62,11 @@ namespace Volo.Abp.TestApp.EntityFrameworkCore d.WithOwner().HasForeignKey(x => x.CityId); d.HasKey(x => new {x.CityId, x.Name}); }); + + b.ApplyObjectExtensionMappings(); }); + + modelBuilder.TryConfigureObjectExtensions(); } } } diff --git a/modules/audit-logging/src/Volo.Abp.AuditLogging.EntityFrameworkCore/Volo/Abp/AuditLogging/EntityFrameworkCore/AbpAuditLoggingDbContextModelBuilderExtensions.cs b/modules/audit-logging/src/Volo.Abp.AuditLogging.EntityFrameworkCore/Volo/Abp/AuditLogging/EntityFrameworkCore/AbpAuditLoggingDbContextModelBuilderExtensions.cs index b44242e511..494e4cefde 100644 --- a/modules/audit-logging/src/Volo.Abp.AuditLogging.EntityFrameworkCore/Volo/Abp/AuditLogging/EntityFrameworkCore/AbpAuditLoggingDbContextModelBuilderExtensions.cs +++ b/modules/audit-logging/src/Volo.Abp.AuditLogging.EntityFrameworkCore/Volo/Abp/AuditLogging/EntityFrameworkCore/AbpAuditLoggingDbContextModelBuilderExtensions.cs @@ -39,7 +39,7 @@ namespace Volo.Abp.AuditLogging.EntityFrameworkCore if (builder.IsUsingOracle()) { AuditLogConsts.MaxExceptionsLengthValue = 2000; } b.Property(x => x.Exceptions).HasMaxLength(AuditLogConsts.MaxExceptionsLengthValue).HasColumnName(nameof(AuditLog.Exceptions)); - + b.Property(x => x.Comments).HasMaxLength(AuditLogConsts.MaxCommentsLength).HasColumnName(nameof(AuditLog.Comments)); b.Property(x => x.ExecutionDuration).HasColumnName(nameof(AuditLog.ExecutionDuration)); b.Property(x => x.ImpersonatorTenantId).HasColumnName(nameof(AuditLog.ImpersonatorTenantId)); @@ -53,6 +53,8 @@ namespace Volo.Abp.AuditLogging.EntityFrameworkCore b.HasIndex(x => new { x.TenantId, x.ExecutionTime }); b.HasIndex(x => new { x.TenantId, x.UserId, x.ExecutionTime }); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -67,9 +69,11 @@ namespace Volo.Abp.AuditLogging.EntityFrameworkCore b.Property(x => x.Parameters).HasMaxLength(AuditLogActionConsts.MaxParametersLength).HasColumnName(nameof(AuditLogAction.Parameters)); b.Property(x => x.ExecutionTime).HasColumnName(nameof(AuditLogAction.ExecutionTime)); b.Property(x => x.ExecutionDuration).HasColumnName(nameof(AuditLogAction.ExecutionDuration)); - + b.HasIndex(x => new { x.AuditLogId }); b.HasIndex(x => new { x.TenantId, x.ServiceName, x.MethodName, x.ExecutionTime }); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -89,6 +93,8 @@ namespace Volo.Abp.AuditLogging.EntityFrameworkCore b.HasIndex(x => new { x.AuditLogId }); b.HasIndex(x => new { x.TenantId, x.EntityTypeFullName, x.EntityId }); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -103,7 +109,11 @@ namespace Volo.Abp.AuditLogging.EntityFrameworkCore b.Property(x => x.OriginalValue).HasMaxLength(EntityPropertyChangeConsts.MaxOriginalValueLength).HasColumnName(nameof(EntityPropertyChange.OriginalValue)); b.HasIndex(x => new { x.EntityChangeId }); + + b.ApplyObjectExtensionMappings(); }); + + builder.TryConfigureObjectExtensions(); } } } diff --git a/modules/background-jobs/src/Volo.Abp.BackgroundJobs.EntityFrameworkCore/Volo/Abp/BackgroundJobs/EntityFrameworkCore/BackgroundJobsDbContextModelCreatingExtensions.cs b/modules/background-jobs/src/Volo.Abp.BackgroundJobs.EntityFrameworkCore/Volo/Abp/BackgroundJobs/EntityFrameworkCore/BackgroundJobsDbContextModelCreatingExtensions.cs index 0e36a661f6..76d39a77ae 100644 --- a/modules/background-jobs/src/Volo.Abp.BackgroundJobs.EntityFrameworkCore/Volo/Abp/BackgroundJobs/EntityFrameworkCore/BackgroundJobsDbContextModelCreatingExtensions.cs +++ b/modules/background-jobs/src/Volo.Abp.BackgroundJobs.EntityFrameworkCore/Volo/Abp/BackgroundJobs/EntityFrameworkCore/BackgroundJobsDbContextModelCreatingExtensions.cs @@ -39,7 +39,11 @@ namespace Volo.Abp.BackgroundJobs.EntityFrameworkCore b.Property(x => x.Priority).HasDefaultValue(BackgroundJobPriority.Normal); b.HasIndex(x => new { x.IsAbandoned, x.NextTryTime }); + + b.ApplyObjectExtensionMappings(); }); + + builder.TryConfigureObjectExtensions(); } } } diff --git a/modules/blob-storing-database/src/Volo.Abp.BlobStoring.Database.EntityFrameworkCore/Volo/Abp/BlobStoring/Database/EntityFrameworkCore/BlobStoringDbContextModelCreatingExtensions.cs b/modules/blob-storing-database/src/Volo.Abp.BlobStoring.Database.EntityFrameworkCore/Volo/Abp/BlobStoring/Database/EntityFrameworkCore/BlobStoringDbContextModelCreatingExtensions.cs index be8625e9e6..ddcaae7911 100644 --- a/modules/blob-storing-database/src/Volo.Abp.BlobStoring.Database.EntityFrameworkCore/Volo/Abp/BlobStoring/Database/EntityFrameworkCore/BlobStoringDbContextModelCreatingExtensions.cs +++ b/modules/blob-storing-database/src/Volo.Abp.BlobStoring.Database.EntityFrameworkCore/Volo/Abp/BlobStoring/Database/EntityFrameworkCore/BlobStoringDbContextModelCreatingExtensions.cs @@ -30,6 +30,8 @@ namespace Volo.Abp.BlobStoring.Database.EntityFrameworkCore b.HasMany().WithOne().HasForeignKey(p => p.ContainerId); b.HasIndex(x => new {x.TenantId, x.Name}); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -45,7 +47,11 @@ namespace Volo.Abp.BlobStoring.Database.EntityFrameworkCore b.HasOne().WithMany().HasForeignKey(p => p.ContainerId); b.HasIndex(x => new {x.TenantId, x.ContainerId, x.Name}); + + b.ApplyObjectExtensionMappings(); }); + + builder.TryConfigureObjectExtensions(); } } -} \ No newline at end of file +} diff --git a/modules/blogging/src/Volo.Blogging.EntityFrameworkCore/Volo/Blogging/EntityFrameworkCore/BloggingDbContextModelBuilderExtensions.cs b/modules/blogging/src/Volo.Blogging.EntityFrameworkCore/Volo/Blogging/EntityFrameworkCore/BloggingDbContextModelBuilderExtensions.cs index 9c54d0a3a0..4a0d23a0fb 100644 --- a/modules/blogging/src/Volo.Blogging.EntityFrameworkCore/Volo/Blogging/EntityFrameworkCore/BloggingDbContextModelBuilderExtensions.cs +++ b/modules/blogging/src/Volo.Blogging.EntityFrameworkCore/Volo/Blogging/EntityFrameworkCore/BloggingDbContextModelBuilderExtensions.cs @@ -38,6 +38,8 @@ namespace Volo.Blogging.EntityFrameworkCore b.ConfigureByConvention(); b.ConfigureAbpUser(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -49,6 +51,8 @@ namespace Volo.Blogging.EntityFrameworkCore b.Property(x => x.Name).IsRequired().HasMaxLength(BlogConsts.MaxNameLength).HasColumnName(nameof(Blog.Name)); b.Property(x => x.ShortName).IsRequired().HasMaxLength(BlogConsts.MaxShortNameLength).HasColumnName(nameof(Blog.ShortName)); b.Property(x => x.Description).IsRequired(false).HasMaxLength(BlogConsts.MaxDescriptionLength).HasColumnName(nameof(Blog.Description)); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -67,6 +71,8 @@ namespace Volo.Blogging.EntityFrameworkCore b.HasMany(p => p.Tags).WithOne().HasForeignKey(qt => qt.PostId); b.HasOne().WithMany().IsRequired().HasForeignKey(p => p.BlogId); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -81,6 +87,8 @@ namespace Volo.Blogging.EntityFrameworkCore b.HasOne().WithMany().HasForeignKey(p => p.RepliedCommentId); b.HasOne().WithMany().IsRequired().HasForeignKey(p => p.PostId); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -94,6 +102,8 @@ namespace Volo.Blogging.EntityFrameworkCore b.Property(x => x.UsageCount).HasColumnName(nameof(Tag.UsageCount)); b.HasMany().WithOne().HasForeignKey(qt => qt.TagId); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -106,7 +116,11 @@ namespace Volo.Blogging.EntityFrameworkCore b.Property(x => x.TagId).HasColumnName(nameof(PostTag.TagId)); b.HasKey(x => new { x.PostId, x.TagId }); + + b.ApplyObjectExtensionMappings(); }); + + builder.TryConfigureObjectExtensions(); } } } diff --git a/modules/cms-kit/src/Volo.CmsKit.EntityFrameworkCore/Volo/CmsKit/EntityFrameworkCore/CmsKitDbContextModelCreatingExtensions.cs b/modules/cms-kit/src/Volo.CmsKit.EntityFrameworkCore/Volo/CmsKit/EntityFrameworkCore/CmsKitDbContextModelCreatingExtensions.cs index 284d4b0e33..6cfe2ac94b 100644 --- a/modules/cms-kit/src/Volo.CmsKit.EntityFrameworkCore/Volo/CmsKit/EntityFrameworkCore/CmsKitDbContextModelCreatingExtensions.cs +++ b/modules/cms-kit/src/Volo.CmsKit.EntityFrameworkCore/Volo/CmsKit/EntityFrameworkCore/CmsKitDbContextModelCreatingExtensions.cs @@ -42,6 +42,8 @@ namespace Volo.CmsKit.EntityFrameworkCore b.HasIndex(x => new { x.TenantId, x.UserName }); b.HasIndex(x => new { x.TenantId, x.Email }); + + b.ApplyObjectExtensionMappings(); }); } else @@ -63,6 +65,8 @@ namespace Volo.CmsKit.EntityFrameworkCore b.HasIndex(x => new { x.TenantId, x.EntityType, x.EntityId, x.ReactionName }); b.HasIndex(x => new { x.TenantId, x.CreatorId, x.EntityType, x.EntityId, x.ReactionName }); + + b.ApplyObjectExtensionMappings(); }); } else @@ -85,6 +89,8 @@ namespace Volo.CmsKit.EntityFrameworkCore b.HasIndex(x => new { x.TenantId, x.EntityType, x.EntityId }); b.HasIndex(x => new { x.TenantId, x.RepliedCommentId }); + + b.ApplyObjectExtensionMappings(); }); } else @@ -105,6 +111,8 @@ namespace Volo.CmsKit.EntityFrameworkCore r.Property(x => x.EntityId).IsRequired().HasMaxLength(RatingConsts.MaxEntityIdLength); r.HasIndex(x => new { x.TenantId, x.EntityType, x.EntityId, x.CreatorId }); + + r.ApplyObjectExtensionMappings(); }); } else @@ -128,6 +136,8 @@ namespace Volo.CmsKit.EntityFrameworkCore x.TenantId, x.Name }); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -142,6 +152,8 @@ namespace Volo.CmsKit.EntityFrameworkCore b.Property(x => x.TagId).IsRequired(); b.HasIndex(x => new { x.TenantId, x.EntityId, x.TagId }); + + b.ApplyObjectExtensionMappings(); }); } else @@ -163,6 +175,8 @@ namespace Volo.CmsKit.EntityFrameworkCore b.Property(x => x.Content).HasMaxLength(PageConsts.MaxContentLength); b.HasIndex(x => new { x.TenantId, Url = x.Slug }); + + b.ApplyObjectExtensionMappings(); }); } else @@ -181,6 +195,8 @@ namespace Volo.CmsKit.EntityFrameworkCore b.Property(p => p.Name).IsRequired().HasMaxLength(BlogConsts.MaxNameLength); b.Property(p => p.Slug).IsRequired().HasMaxLength(BlogConsts.MaxSlugLength); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -194,8 +210,10 @@ namespace Volo.CmsKit.EntityFrameworkCore b.Property(p => p.Slug).IsRequired().HasMaxLength(BlogPostConsts.MaxSlugLength); b.Property(p => p.ShortDescription).HasMaxLength(BlogPostConsts.MaxShortDescriptionLength); b.Property(p => p.Content).HasMaxLength(BlogPostConsts.MaxContentLength); - + b.HasIndex(x => new { x.Slug, x.BlogId }); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -205,6 +223,8 @@ namespace Volo.CmsKit.EntityFrameworkCore b.ConfigureByConvention(); b.Property(p => p.FeatureName).IsRequired().HasMaxLength(BlogFeatureConsts.MaxFeatureNameLenth); + + b.ApplyObjectExtensionMappings(); }); } else @@ -226,12 +246,16 @@ namespace Volo.CmsKit.EntityFrameworkCore b.Property(x => x.Name).IsRequired().HasMaxLength(MediaDescriptorConsts.MaxNameLength); b.Property(x => x.MimeType).IsRequired().HasMaxLength(MediaDescriptorConsts.MaxMimeTypeLength); b.Property(x => x.Size).HasMaxLength(MediaDescriptorConsts.MaxSizeLength); + + b.ApplyObjectExtensionMappings(); }); } else { builder.Ignore(); } + + builder.TryConfigureObjectExtensions(); } } -} \ No newline at end of file +} diff --git a/modules/docs/src/Volo.Docs.EntityFrameworkCore/Volo/Docs/EntityFrameworkCore/DocsDbContextModelBuilderExtensions.cs b/modules/docs/src/Volo.Docs.EntityFrameworkCore/Volo/Docs/EntityFrameworkCore/DocsDbContextModelBuilderExtensions.cs index c751475728..6f7c7d1a89 100644 --- a/modules/docs/src/Volo.Docs.EntityFrameworkCore/Volo/Docs/EntityFrameworkCore/DocsDbContextModelBuilderExtensions.cs +++ b/modules/docs/src/Volo.Docs.EntityFrameworkCore/Volo/Docs/EntityFrameworkCore/DocsDbContextModelBuilderExtensions.cs @@ -40,6 +40,8 @@ namespace Volo.Docs.EntityFrameworkCore b.Property(x => x.NavigationDocumentName).IsRequired().HasMaxLength(ProjectConsts.MaxNavigationDocumentNameLength); b.Property(x => x.ParametersDocumentName).IsRequired().HasMaxLength(ProjectConsts.MaxParametersDocumentNameLength); b.Property(x => x.LatestVersionBranchName).HasMaxLength(ProjectConsts.MaxLatestVersionBranchNameLength); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -62,6 +64,8 @@ namespace Volo.Docs.EntityFrameworkCore b.HasMany(x => x.Contributors).WithOne() .HasForeignKey(x => new { x.DocumentId }) .IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -71,7 +75,11 @@ namespace Volo.Docs.EntityFrameworkCore b.ConfigureByConvention(); b.HasKey(x => new { x.DocumentId, x.Username }); + + b.ApplyObjectExtensionMappings(); }); + + builder.TryConfigureObjectExtensions(); } } } diff --git a/modules/feature-management/src/Volo.Abp.FeatureManagement.EntityFrameworkCore/Volo/Abp/FeatureManagement/EntityFrameworkCore/FeatureManagementDbContextModelCreatingExtensions.cs b/modules/feature-management/src/Volo.Abp.FeatureManagement.EntityFrameworkCore/Volo/Abp/FeatureManagement/EntityFrameworkCore/FeatureManagementDbContextModelCreatingExtensions.cs index 0398096b95..b482788e49 100644 --- a/modules/feature-management/src/Volo.Abp.FeatureManagement.EntityFrameworkCore/Volo/Abp/FeatureManagement/EntityFrameworkCore/FeatureManagementDbContextModelCreatingExtensions.cs +++ b/modules/feature-management/src/Volo.Abp.FeatureManagement.EntityFrameworkCore/Volo/Abp/FeatureManagement/EntityFrameworkCore/FeatureManagementDbContextModelCreatingExtensions.cs @@ -36,7 +36,11 @@ namespace Volo.Abp.FeatureManagement.EntityFrameworkCore b.Property(x => x.ProviderKey).HasMaxLength(FeatureValueConsts.MaxProviderKeyLength); b.HasIndex(x => new { x.Name, x.ProviderName, x.ProviderKey }); + + b.ApplyObjectExtensionMappings(); }); + + builder.TryConfigureObjectExtensions(); } } } diff --git a/modules/identity/src/Volo.Abp.Identity.EntityFrameworkCore/Volo/Abp/Identity/EntityFrameworkCore/IdentityDbContextModelBuilderExtensions.cs b/modules/identity/src/Volo.Abp.Identity.EntityFrameworkCore/Volo/Abp/Identity/EntityFrameworkCore/IdentityDbContextModelBuilderExtensions.cs index 4e43721a80..204eab3d6f 100644 --- a/modules/identity/src/Volo.Abp.Identity.EntityFrameworkCore/Volo/Abp/Identity/EntityFrameworkCore/IdentityDbContextModelBuilderExtensions.cs +++ b/modules/identity/src/Volo.Abp.Identity.EntityFrameworkCore/Volo/Abp/Identity/EntityFrameworkCore/IdentityDbContextModelBuilderExtensions.cs @@ -60,6 +60,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.HasIndex(u => u.NormalizedEmail); b.HasIndex(u => u.UserName); b.HasIndex(u => u.Email); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -74,6 +76,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.Property(uc => uc.ClaimValue).HasMaxLength(IdentityUserClaimConsts.MaxClaimValueLength); b.HasIndex(uc => uc.UserId); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -88,6 +92,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.HasOne().WithMany(u => u.Roles).HasForeignKey(ur => ur.UserId).IsRequired(); b.HasIndex(ur => new {ur.RoleId, ur.UserId}); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -106,6 +112,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore .HasMaxLength(IdentityUserLoginConsts.MaxProviderDisplayNameLength); b.HasIndex(l => new {l.LoginProvider, l.ProviderKey}); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -119,6 +127,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.Property(ul => ul.LoginProvider).HasMaxLength(IdentityUserTokenConsts.MaxLoginProviderLength) .IsRequired(); b.Property(ul => ul.Name).HasMaxLength(IdentityUserTokenConsts.MaxNameLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -136,6 +146,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.HasMany(r => r.Claims).WithOne().HasForeignKey(rc => rc.RoleId).IsRequired(); b.HasIndex(r => r.NormalizedName); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -150,6 +162,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.Property(uc => uc.ClaimValue).HasMaxLength(IdentityRoleClaimConsts.MaxClaimValueLength); b.HasIndex(uc => uc.RoleId); + + b.ApplyObjectExtensionMappings(); }); if (builder.IsHostDatabase()) @@ -165,6 +179,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.Property(uc => uc.Regex).HasMaxLength(IdentityClaimTypeConsts.MaxRegexLength); b.Property(uc => uc.RegexDescription).HasMaxLength(IdentityClaimTypeConsts.MaxRegexDescriptionLength); b.Property(uc => uc.Description).HasMaxLength(IdentityClaimTypeConsts.MaxDescriptionLength); + + b.ApplyObjectExtensionMappings(); }); } @@ -183,6 +199,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.HasMany(ou => ou.Roles).WithOne().HasForeignKey(our => our.OrganizationUnitId).IsRequired(); b.HasIndex(ou => ou.Code); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -196,6 +214,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.HasOne().WithMany().HasForeignKey(ou => ou.RoleId).IsRequired(); b.HasIndex(ou => new {ou.RoleId, ou.OrganizationUnitId}); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -209,6 +229,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.HasOne().WithMany().HasForeignKey(ou => ou.OrganizationUnitId).IsRequired(); b.HasIndex(ou => new {ou.UserId, ou.OrganizationUnitId}); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -234,6 +256,8 @@ namespace Volo.Abp.Identity.EntityFrameworkCore b.HasIndex(x => new { x.TenantId, x.Identity }); b.HasIndex(x => new { x.TenantId, x.Action }); b.HasIndex(x => new { x.TenantId, x.UserId }); + + b.ApplyObjectExtensionMappings(); }); if (builder.IsHostDatabase()) @@ -251,8 +275,12 @@ namespace Volo.Abp.Identity.EntityFrameworkCore LinkedUserId = x.TargetUserId, LinkedTenantId = x.TargetTenantId }).IsUnique(); + + b.ApplyObjectExtensionMappings(); }); } + + builder.TryConfigureObjectExtensions(); } } } diff --git a/modules/identityserver/src/Volo.Abp.IdentityServer.EntityFrameworkCore/Volo/Abp/IdentityServer/EntityFrameworkCore/IdentityServerDbContextModelCreatingExtensions.cs b/modules/identityserver/src/Volo.Abp.IdentityServer.EntityFrameworkCore/Volo/Abp/IdentityServer/EntityFrameworkCore/IdentityServerDbContextModelCreatingExtensions.cs index d3d08dca15..c8b0dc0682 100644 --- a/modules/identityserver/src/Volo.Abp.IdentityServer.EntityFrameworkCore/Volo/Abp/IdentityServer/EntityFrameworkCore/IdentityServerDbContextModelCreatingExtensions.cs +++ b/modules/identityserver/src/Volo.Abp.IdentityServer.EntityFrameworkCore/Volo/Abp/IdentityServer/EntityFrameworkCore/IdentityServerDbContextModelCreatingExtensions.cs @@ -63,6 +63,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasMany(x => x.Properties).WithOne().HasForeignKey(x => x.ClientId).IsRequired(); b.HasIndex(x => x.ClientId); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -74,6 +76,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasKey(x => new {x.ClientId, x.GrantType}); b.Property(x => x.GrantType).HasMaxLength(ClientGrantTypeConsts.GrantTypeMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -90,6 +94,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore } b.Property(x => x.RedirectUri).HasMaxLength(ClientRedirectUriConsts.RedirectUriMaxLengthValue).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -108,6 +114,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.Property(x => x.PostLogoutRedirectUri) .HasMaxLength(ClientPostLogoutRedirectUriConsts.PostLogoutRedirectUriMaxLengthValue) .IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -119,6 +127,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasKey(x => new {x.ClientId, x.Scope}); b.Property(x => x.Scope).HasMaxLength(ClientScopeConsts.ScopeMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -136,6 +146,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore } b.Property(x => x.Value).HasMaxLength(ClientSecretConsts.ValueMaxLength).IsRequired(); b.Property(x => x.Description).HasMaxLength(ClientSecretConsts.DescriptionMaxLength); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -148,6 +160,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.Property(x => x.Type).HasMaxLength(ClientClaimConsts.TypeMaxLength).IsRequired(); b.Property(x => x.Value).HasMaxLength(ClientClaimConsts.ValueMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -159,6 +173,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasKey(x => new {x.ClientId, x.Provider}); b.Property(x => x.Provider).HasMaxLength(ClientIdPRestrictionConsts.ProviderMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -170,6 +186,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasKey(x => new {x.ClientId, x.Origin}); b.Property(x => x.Origin).HasMaxLength(ClientCorsOriginConsts.OriginMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -186,6 +204,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore ClientPropertyConsts.ValueMaxLength = 300; } b.Property(x => x.Value).HasMaxLength(ClientPropertyConsts.ValueMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); #endregion @@ -204,6 +224,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasMany(x => x.UserClaims).WithOne().HasForeignKey(x => x.IdentityResourceId).IsRequired(); b.HasMany(x => x.Properties).WithOne().HasForeignKey(x => x.IdentityResourceId).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -215,6 +237,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasKey(x => new {x.IdentityResourceId, x.Type}); b.Property(x => x.Type).HasMaxLength(UserClaimConsts.TypeMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -231,6 +255,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore IdentityResourcePropertyConsts.ValueMaxLength = 300; } b.Property(x => x.Value).HasMaxLength(IdentityResourcePropertyConsts.ValueMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); #endregion @@ -252,6 +278,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasMany(x => x.Scopes).WithOne().HasForeignKey(x => x.ApiResourceId).IsRequired(); b.HasMany(x => x.UserClaims).WithOne().HasForeignKey(x => x.ApiResourceId).IsRequired(); b.HasMany(x => x.Properties).WithOne().HasForeignKey(x => x.ApiResourceId).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -271,6 +299,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.Property(x => x.Value).HasMaxLength(ApiResourceSecretConsts.ValueMaxLength).IsRequired(); b.Property(x => x.Description).HasMaxLength(ApiResourceSecretConsts.DescriptionMaxLength); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -282,6 +312,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasKey(x => new {x.ApiResourceId, x.Type}); b.Property(x => x.Type).HasMaxLength(UserClaimConsts.TypeMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -293,6 +325,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasKey(x => new {x.ApiResourceId, x.Scope}); b.Property(x => x.Scope).HasMaxLength(ApiResourceScopeConsts.ScopeMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -309,6 +343,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore ApiResourcePropertyConsts.ValueMaxLength = 300; } b.Property(x => x.Value).HasMaxLength(ApiResourcePropertyConsts.ValueMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); #endregion @@ -327,6 +363,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasMany(x => x.UserClaims).WithOne().HasForeignKey(x => x.ApiScopeId).IsRequired(); b.HasMany(x => x.Properties).WithOne().HasForeignKey(x => x.ApiScopeId).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -338,6 +376,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasKey(x => new {x.ApiScopeId, x.Type}); b.Property(x => x.Type).HasMaxLength(UserClaimConsts.TypeMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -354,6 +394,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore ApiScopePropertyConsts.ValueMaxLength = 300; } b.Property(x => x.Value).HasMaxLength(ApiScopePropertyConsts.ValueMaxLength).IsRequired(); + + b.ApplyObjectExtensionMappings(); }); #endregion @@ -386,6 +428,8 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasIndex(x => new {x.SubjectId, x.ClientId, x.Type}); b.HasIndex(x => new {x.SubjectId, x.SessionId, x.Type}); b.HasIndex(x => x.Expiration); + + b.ApplyObjectExtensionMappings(); }); #endregion @@ -416,9 +460,13 @@ namespace Volo.Abp.IdentityServer.EntityFrameworkCore b.HasIndex(x => new {x.UserCode}); b.HasIndex(x => x.DeviceCode).IsUnique(); b.HasIndex(x => x.Expiration); + + b.ApplyObjectExtensionMappings(); }); #endregion + + builder.TryConfigureObjectExtensions(); } private static bool IsDatabaseProvider( diff --git a/modules/permission-management/src/Volo.Abp.PermissionManagement.EntityFrameworkCore/Volo/Abp/PermissionManagement/EntityFrameworkCore/AbpPermissionManagementDbContextModelBuilderExtensions.cs b/modules/permission-management/src/Volo.Abp.PermissionManagement.EntityFrameworkCore/Volo/Abp/PermissionManagement/EntityFrameworkCore/AbpPermissionManagementDbContextModelBuilderExtensions.cs index 419389568a..8810f4a0bc 100644 --- a/modules/permission-management/src/Volo.Abp.PermissionManagement.EntityFrameworkCore/Volo/Abp/PermissionManagement/EntityFrameworkCore/AbpPermissionManagementDbContextModelBuilderExtensions.cs +++ b/modules/permission-management/src/Volo.Abp.PermissionManagement.EntityFrameworkCore/Volo/Abp/PermissionManagement/EntityFrameworkCore/AbpPermissionManagementDbContextModelBuilderExtensions.cs @@ -31,7 +31,11 @@ namespace Volo.Abp.PermissionManagement.EntityFrameworkCore b.Property(x => x.ProviderKey).HasMaxLength(PermissionGrantConsts.MaxProviderKeyLength).IsRequired(); b.HasIndex(x => new {x.Name, x.ProviderName, x.ProviderKey}); + + b.ApplyObjectExtensionMappings(); }); + + builder.TryConfigureObjectExtensions(); } } -} \ No newline at end of file +} diff --git a/modules/setting-management/src/Volo.Abp.SettingManagement.EntityFrameworkCore/Volo/Abp/SettingManagement/EntityFrameworkCore/SettingManagementDbContextModelBuilderExtensions.cs b/modules/setting-management/src/Volo.Abp.SettingManagement.EntityFrameworkCore/Volo/Abp/SettingManagement/EntityFrameworkCore/SettingManagementDbContextModelBuilderExtensions.cs index 0758cc9957..5e9f75eefa 100644 --- a/modules/setting-management/src/Volo.Abp.SettingManagement.EntityFrameworkCore/Volo/Abp/SettingManagement/EntityFrameworkCore/SettingManagementDbContextModelBuilderExtensions.cs +++ b/modules/setting-management/src/Volo.Abp.SettingManagement.EntityFrameworkCore/Volo/Abp/SettingManagement/EntityFrameworkCore/SettingManagementDbContextModelBuilderExtensions.cs @@ -54,7 +54,11 @@ namespace Volo.Abp.SettingManagement.EntityFrameworkCore b.Property(x => x.ProviderKey).HasMaxLength(SettingConsts.MaxProviderKeyLength); b.HasIndex(x => new {x.Name, x.ProviderName, x.ProviderKey}); + + b.ApplyObjectExtensionMappings(); }); + + builder.TryConfigureObjectExtensions(); } } } diff --git a/modules/tenant-management/src/Volo.Abp.TenantManagement.EntityFrameworkCore/Volo/Abp/TenantManagement/EntityFrameworkCore/AbpTenantManagementDbContextModelCreatingExtensions.cs b/modules/tenant-management/src/Volo.Abp.TenantManagement.EntityFrameworkCore/Volo/Abp/TenantManagement/EntityFrameworkCore/AbpTenantManagementDbContextModelCreatingExtensions.cs index 04c97046cf..398dc66fe5 100644 --- a/modules/tenant-management/src/Volo.Abp.TenantManagement.EntityFrameworkCore/Volo/Abp/TenantManagement/EntityFrameworkCore/AbpTenantManagementDbContextModelCreatingExtensions.cs +++ b/modules/tenant-management/src/Volo.Abp.TenantManagement.EntityFrameworkCore/Volo/Abp/TenantManagement/EntityFrameworkCore/AbpTenantManagementDbContextModelCreatingExtensions.cs @@ -36,6 +36,8 @@ namespace Volo.Abp.TenantManagement.EntityFrameworkCore b.HasMany(u => u.ConnectionStrings).WithOne().HasForeignKey(uc => uc.TenantId).IsRequired(); b.HasIndex(u => u.Name); + + b.ApplyObjectExtensionMappings(); }); builder.Entity(b => @@ -48,7 +50,11 @@ namespace Volo.Abp.TenantManagement.EntityFrameworkCore b.Property(cs => cs.Name).IsRequired().HasMaxLength(TenantConnectionStringConsts.MaxNameLength); b.Property(cs => cs.Value).IsRequired().HasMaxLength(TenantConnectionStringConsts.MaxValueLength); + + b.ApplyObjectExtensionMappings(); }); + + builder.TryConfigureObjectExtensions(); } } }