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
85 lines
3.9 KiB
C#
85 lines
3.9 KiB
C#
using System.Reflection;
|
|
using CMSMicroservice.Application.Common.Interfaces;
|
|
using CMSMicroservice.Domain.Entities;
|
|
using CMSMicroservice.Infrastructure.Persistence.Interceptors;
|
|
using MediatR;
|
|
using Microsoft.EntityFrameworkCore;
|
|
|
|
namespace CMSMicroservice.Infrastructure.Persistence;
|
|
|
|
public class ApplicationDbContext : DbContext, IApplicationDbContext
|
|
{
|
|
private readonly IMediator _mediator;
|
|
private readonly AuditableEntitySaveChangesInterceptor _auditableEntitySaveChangesInterceptor;
|
|
|
|
public ApplicationDbContext(
|
|
DbContextOptions<ApplicationDbContext> options,
|
|
IMediator mediator,
|
|
AuditableEntitySaveChangesInterceptor auditableEntitySaveChangesInterceptor)
|
|
: base(options)
|
|
{
|
|
_mediator = mediator;
|
|
_auditableEntitySaveChangesInterceptor = auditableEntitySaveChangesInterceptor;
|
|
}
|
|
protected override void OnModelCreating(ModelBuilder builder)
|
|
{
|
|
builder.ApplyConfigurationsFromAssembly(Assembly.GetExecutingAssembly());
|
|
builder.HasDefaultSchema("CMS");
|
|
base.OnModelCreating(builder);
|
|
}
|
|
|
|
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
|
|
{
|
|
optionsBuilder.AddInterceptors(_auditableEntitySaveChangesInterceptor);
|
|
}
|
|
|
|
public override async Task<int> SaveChangesAsync(CancellationToken cancellationToken = default)
|
|
{
|
|
await _mediator.DispatchDomainEvents(this);
|
|
|
|
return await base.SaveChangesAsync(cancellationToken);
|
|
}
|
|
public DbSet<UserAddress> UserAddresss => Set<UserAddress>();
|
|
public DbSet<Package> Packages => Set<Package>();
|
|
public DbSet<Role> Roles => Set<Role>();
|
|
public DbSet<Category> Categorys => Set<Category>();
|
|
public DbSet<UserRole> UserRoles => Set<UserRole>();
|
|
public DbSet<UserCarts> UserCartss => Set<UserCarts>();
|
|
public DbSet<ProductGallerys> ProductGalleryss => Set<ProductGallerys>();
|
|
public DbSet<FactorDetails> FactorDetailss => Set<FactorDetails>();
|
|
public DbSet<Products> Productss => Set<Products>();
|
|
public DbSet<ProductImages> ProductImagess => Set<ProductImages>();
|
|
public DbSet<User> Users => Set<User>();
|
|
public DbSet<OtpToken> OtpTokens => Set<OtpToken>();
|
|
public DbSet<Contract> Contracts => Set<Contract>();
|
|
public DbSet<UserContract> UserContracts => Set<UserContract>();
|
|
public DbSet<Tag> Tags => Set<Tag>();
|
|
public DbSet<PruductCategory> PruductCategorys => Set<PruductCategory>();
|
|
public DbSet<PruductTag> PruductTags => Set<PruductTag>();
|
|
public DbSet<Transactions> Transactionss => Set<Transactions>();
|
|
public DbSet<UserOrder> UserOrders => Set<UserOrder>();
|
|
public DbSet<UserWallet> UserWallets => Set<UserWallet>();
|
|
public DbSet<UserWalletChangeLog> UserWalletChangeLogs => Set<UserWalletChangeLog>();
|
|
|
|
// ============= Network Club System DbSets =============
|
|
|
|
// Configuration
|
|
public DbSet<SystemConfiguration> SystemConfigurations => Set<SystemConfiguration>();
|
|
public DbSet<SystemConfigurationHistory> SystemConfigurationHistories => Set<SystemConfigurationHistory>();
|
|
|
|
// Club Management
|
|
public DbSet<ClubMembership> ClubMemberships => Set<ClubMembership>();
|
|
public DbSet<ClubFeature> ClubFeatures => Set<ClubFeature>();
|
|
public DbSet<UserClubFeature> UserClubFeatures => Set<UserClubFeature>();
|
|
public DbSet<ClubMembershipHistory> ClubMembershipHistories => Set<ClubMembershipHistory>();
|
|
|
|
// Network
|
|
public DbSet<NetworkWeeklyBalance> NetworkWeeklyBalances => Set<NetworkWeeklyBalance>();
|
|
public DbSet<NetworkMembershipHistory> NetworkMembershipHistories => Set<NetworkMembershipHistory>();
|
|
|
|
// Commission
|
|
public DbSet<WeeklyCommissionPool> WeeklyCommissionPools => Set<WeeklyCommissionPool>();
|
|
public DbSet<UserCommissionPayout> UserCommissionPayouts => Set<UserCommissionPayout>();
|
|
public DbSet<CommissionPayoutHistory> CommissionPayoutHistories => Set<CommissionPayoutHistory>();
|
|
}
|