Files
budget/src/Budget.Infrastructure/Data/AppDbContext.cs
T
2026-05-03 07:20:19 -05:00

68 lines
2.8 KiB
C#

using Budget.Core.Models;
using Microsoft.EntityFrameworkCore;
namespace Budget.Infrastructure.Data;
public class AppDbContext(DbContextOptions<AppDbContext> options) : DbContext(options)
{
public DbSet<Budget.Core.Models.Budget> Budgets => Set<Budget.Core.Models.Budget>();
public DbSet<Income> Incomes => Set<Income>();
public DbSet<Outgo> Outgos => Set<Outgo>();
public DbSet<KnownUser> KnownUsers => Set<KnownUser>();
public DbSet<BudgetShare> BudgetShares => Set<BudgetShare>();
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.Entity<Budget.Core.Models.Budget>(b =>
{
b.HasKey(x => x.Id);
b.Property(x => x.Name).IsRequired().HasMaxLength(200);
b.Property(x => x.OwnerUserId).IsRequired().HasMaxLength(200);
b.HasMany(x => x.Incomes).WithOne(i => i.Budget).HasForeignKey(i => i.BudgetId).OnDelete(DeleteBehavior.Cascade);
b.HasMany(x => x.Outgos).WithOne(o => o.Budget).HasForeignKey(o => o.BudgetId).OnDelete(DeleteBehavior.Cascade);
b.HasMany(x => x.Shares).WithOne(s => s.Budget).HasForeignKey(s => s.BudgetId).OnDelete(DeleteBehavior.Cascade);
b.HasQueryFilter(x => !x.IsDeleted);
b.Property<uint>("xmin")
.HasColumnType("xid")
.ValueGeneratedOnAddOrUpdate()
.IsConcurrencyToken();
});
modelBuilder.Entity<Income>(b =>
{
b.HasKey(x => x.Id);
b.Property(x => x.Name).IsRequired().HasMaxLength(200);
b.Property(x => x.Amount).HasPrecision(18, 2);
b.HasQueryFilter(x => !x.IsDeleted);
});
modelBuilder.Entity<Outgo>(b =>
{
b.HasKey(x => x.Id);
b.Property(x => x.Name).IsRequired().HasMaxLength(200);
b.Property(x => x.Category).HasMaxLength(100);
b.Property(x => x.PaymentSource).HasMaxLength(100);
b.Property(x => x.Notes).HasMaxLength(1000);
b.Property(x => x.Amount).HasPrecision(18, 2);
b.HasQueryFilter(x => !x.IsDeleted);
});
modelBuilder.Entity<KnownUser>(b =>
{
b.HasKey(x => x.Id);
b.Property(x => x.Id).HasMaxLength(200);
b.Property(x => x.Email).IsRequired().HasMaxLength(200);
b.Property(x => x.Name).IsRequired().HasMaxLength(200);
});
modelBuilder.Entity<BudgetShare>(b =>
{
b.HasKey(x => x.Id);
b.Property(x => x.SharedWithUserId).HasMaxLength(200);
b.Property(x => x.SharedWithEmail).IsRequired().HasMaxLength(200);
b.HasIndex(x => new { x.BudgetId, x.SharedWithEmail }).IsUnique();
b.HasQueryFilter(x => !x.IsDeleted);
});
}
}