68 lines
2.8 KiB
C#
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);
|
|
});
|
|
}
|
|
}
|