CodeLiturgy.Dashboard/BlueWest.Api/MySQL/UserDbContext.cs

50 lines
1.3 KiB
C#
Raw Normal View History

2022-08-04 03:59:04 +03:00
using System;
using BlueWest.Data;
using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Configuration;
namespace BlueWest.WebApi.MySQL;
2022-08-13 06:35:36 +03:00
public sealed class UserDbContext : DbContext
2022-08-04 03:59:04 +03:00
{
public DbSet<User> Users { get; set; }
public DbSet<FinanceTransaction> Transactions { get; set; }
2022-08-13 06:35:36 +03:00
public DbSet<FinanceTransactionType> TransactionTypes { get; set; }
2022-08-04 03:59:04 +03:00
public IConfiguration Configuration;
2022-08-13 06:35:36 +03:00
public UserDbContext(DbContextOptions<UserDbContext> options) : base(options)
2022-08-04 03:59:04 +03:00
{
Database.EnsureCreated();
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
/*optionsBuilder.UseMySql(
Configuration.GetConnectionString("LocalMySQL"),
new MySqlServerVersion(new Version(8, 0, 11))
);*/
}
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
base.OnModelCreating(modelBuilder);
modelBuilder.Entity<User>(builder =>
{
builder.HasKey(x => x.Id);
});
modelBuilder.Entity<FinanceTransaction>(builder =>
{
builder.HasOne<User>()
.WithMany(x => x.FinanceTransactions)
.HasForeignKey(x => x.UserId);
});
2022-08-13 06:35:36 +03:00
2022-08-04 03:59:04 +03:00
}
}