feat: Add EF configurations and migration for network-club system

EF Core Configurations (11 files):
- SystemConfigurationConfiguration with Scope+Key composite index
- ClubMembershipConfiguration with one-to-one User relationship
- ClubFeatureConfiguration with IsActive+SortOrder index
- UserClubFeatureConfiguration with composite unique index
- NetworkWeeklyBalanceConfiguration with UserId+WeekNumber index
- WeeklyCommissionPoolConfiguration with unique WeekNumber
- UserCommissionPayoutConfiguration with multiple indexes
- ClubMembershipHistoryConfiguration for audit trail
- NetworkMembershipHistoryConfiguration for audit trail
- CommissionPayoutHistoryConfiguration for audit trail
- SystemConfigurationHistoryConfiguration for audit trail

Configuration Updates:
- UserConfiguration: Add NetworkParentId, LegPosition with indexes
- UserWalletConfiguration: Add DiscountBalance field
- ProductsConfiguration: Add IsClubExclusive, ClubDiscountPercent with index

Infrastructure Updates:
- ApplicationDbContext: Add 11 new DbSets for network-club entities
- GlobalUsings: Add Domain entity namespaces

Migration:
- AddNetworkClubSystemV2: Complete database schema for network-club system
This commit is contained in:
masoodafar-web
2025-11-29 03:52:46 +03:30
parent d20dc86d2f
commit 04bc593184
19 changed files with 4246 additions and 2 deletions

View File

@@ -0,0 +1,52 @@
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Metadata.Builders;
namespace CMSMicroservice.Infrastructure.Persistence.Configurations;
/// <summary>
/// جدول واسط کاربر-فیچر
/// </summary>
public class UserClubFeatureConfiguration : IEntityTypeConfiguration<UserClubFeature>
{
public void Configure(EntityTypeBuilder<UserClubFeature> builder)
{
builder.HasQueryFilter(p => !p.IsDeleted);
builder.Ignore(entity => entity.DomainEvents);
builder.HasKey(entity => entity.Id);
builder.Property(entity => entity.Id).UseIdentityColumn();
builder.Property(entity => entity.UserId).IsRequired();
builder.Property(entity => entity.ClubMembershipId).IsRequired();
builder.Property(entity => entity.ClubFeatureId).IsRequired();
builder.Property(entity => entity.GrantedAt).IsRequired();
builder.Property(entity => entity.Notes).IsRequired(false).HasMaxLength(500);
// رابطه با User
builder.HasOne(entity => entity.User)
.WithMany(u => u.UserClubFeatures)
.HasForeignKey(entity => entity.UserId)
.OnDelete(DeleteBehavior.Restrict);
// رابطه با ClubMembership
builder.HasOne(entity => entity.ClubMembership)
.WithMany(cm => cm.UserClubFeatures)
.HasForeignKey(entity => entity.ClubMembershipId)
.OnDelete(DeleteBehavior.Restrict);
// رابطه با ClubFeature
builder.HasOne(entity => entity.ClubFeature)
.WithMany(cf => cf.UserClubFeatures)
.HasForeignKey(entity => entity.ClubFeatureId)
.OnDelete(DeleteBehavior.Restrict);
// Composite Index برای جلوگیری از تکرار
builder.HasIndex(e => new { e.UserId, e.ClubFeatureId })
.IsUnique()
.HasDatabaseName("IX_UserClubFeature_UserId_ClubFeatureId");
// Index برای ClubMembershipId
builder.HasIndex(e => e.ClubMembershipId)
.HasDatabaseName("IX_UserClubFeature_ClubMembershipId");
}
}