Add EF object history
This commit is contained in:
parent
e06700458f
commit
703d4751e2
13 changed files with 1288 additions and 14 deletions
|
@ -5,7 +5,7 @@ using Microsoft.EntityFrameworkCore;
|
|||
|
||||
namespace DrinkRateAPI.Contexts;
|
||||
|
||||
public class ApplicationDbContext : IdentityDbContext<DbApplicationUser, IdentityRole<Guid>, Guid>
|
||||
public class ApplicationDbContext : IdentityDbContext<DbApplicationUser, IdentityRole<Guid>, Guid>
|
||||
{
|
||||
public DbSet<DbCompany> Companies { get; set; }
|
||||
public DbSet<DbCompanyRating> CompanyRatings { get; set; }
|
||||
|
@ -21,6 +21,9 @@ public class ApplicationDbContext : IdentityDbContext<DbApplicationUser, Identit
|
|||
public DbSet<DbUserProfileCompanyTableStat> UserProfileCompanyTableStats { get; set; }
|
||||
public DbSet<DbUserProfileProductTableStat> UserProfileProductTableStats { get; set; }
|
||||
|
||||
public DbSet<DbUpdateRecord> UpdateRecords { get; set; }
|
||||
public DbSet<DbUpdateRecordFieldChange> UpdateRecordFieldChanges { get; set; }
|
||||
|
||||
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
|
||||
{
|
||||
var environment = Environment.GetEnvironmentVariable("ASPNETCORE_ENVIRONMENT");
|
||||
|
@ -35,7 +38,7 @@ public class ApplicationDbContext : IdentityDbContext<DbApplicationUser, Identit
|
|||
protected override void OnModelCreating(ModelBuilder modelBuilder)
|
||||
{
|
||||
base.OnModelCreating(modelBuilder);
|
||||
|
||||
|
||||
// Company
|
||||
modelBuilder.Entity<DbCompany>(entity =>
|
||||
{
|
||||
|
@ -189,7 +192,7 @@ public class ApplicationDbContext : IdentityDbContext<DbApplicationUser, Identit
|
|||
|
||||
entity.HasIndex(up => up.UserName)
|
||||
.IsUnique();
|
||||
|
||||
|
||||
entity.HasOne(up => up.ApplicationUser)
|
||||
.WithOne(au => au.UserProfile)
|
||||
.HasForeignKey<DbUserProfile>(up => up.ApplicationUserId);
|
||||
|
@ -218,6 +221,6 @@ public class ApplicationDbContext : IdentityDbContext<DbApplicationUser, Identit
|
|||
entity.HasOne(uppts => uppts.ProductTable)
|
||||
.WithMany();
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
}
|
|
@ -1,6 +1,6 @@
|
|||
namespace DrinkRateAPI.DbEntities;
|
||||
|
||||
public class DbCompany
|
||||
public class DbCompany : DbEntityWithHistory
|
||||
{
|
||||
public Guid Id { get; set; }
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
namespace DrinkRateAPI.DbEntities;
|
||||
|
||||
public class DbCompanyRating
|
||||
public class DbCompanyRating : DbEntityWithHistory
|
||||
{
|
||||
public Guid UserProfileId { get; set; }
|
||||
public DbUserProfile UserProfile { get; set; }
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
namespace DrinkRateAPI.DbEntities;
|
||||
|
||||
public class DbCompanyTableView
|
||||
public class DbCompanyTableView : DbEntityWithHistory
|
||||
{
|
||||
public Guid Id { get; set; }
|
||||
|
||||
|
|
6
DrinkRateAPI/DbEntities/DbEntityWithHistory.cs
Normal file
6
DrinkRateAPI/DbEntities/DbEntityWithHistory.cs
Normal file
|
@ -0,0 +1,6 @@
|
|||
namespace DrinkRateAPI.DbEntities;
|
||||
|
||||
public abstract class DbEntityWithHistory
|
||||
{
|
||||
public ICollection<DbUpdateRecord> History { get; set; }
|
||||
}
|
|
@ -1,6 +1,6 @@
|
|||
namespace DrinkRateAPI.DbEntities;
|
||||
|
||||
public class DbProduct
|
||||
public class DbProduct : DbEntityWithHistory
|
||||
{
|
||||
public Guid Id { get; set; }
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
namespace DrinkRateAPI.DbEntities;
|
||||
|
||||
public class DbProductRating
|
||||
public class DbProductRating : DbEntityWithHistory
|
||||
{
|
||||
public Guid UserProfileId { get; set; }
|
||||
public DbUserProfile UserProfile { get; set; }
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
namespace DrinkRateAPI.DbEntities;
|
||||
|
||||
public class DbProductTableView
|
||||
public class DbProductTableView : DbEntityWithHistory
|
||||
{
|
||||
public Guid Id { get; set; }
|
||||
|
||||
|
|
18
DrinkRateAPI/DbEntities/DbUpdateRecord.cs
Normal file
18
DrinkRateAPI/DbEntities/DbUpdateRecord.cs
Normal file
|
@ -0,0 +1,18 @@
|
|||
namespace DrinkRateAPI.DbEntities;
|
||||
|
||||
public class DbUpdateRecord
|
||||
{
|
||||
public Guid Id { get; set; }
|
||||
public Guid UserProfileId { get; set; }
|
||||
public DbUserProfile UserProfile { get; set; }
|
||||
public DateTime UpdateTime { get; set; }
|
||||
public ICollection<DbUpdateRecordFieldChange> UpdateRecordFieldChanges { get; set; }
|
||||
}
|
||||
|
||||
public class DbUpdateRecordFieldChange
|
||||
{
|
||||
public Guid Id { get; set; }
|
||||
public string Field { get; set; }
|
||||
public string OldValue { get; set; }
|
||||
public string NewValue { get; set; }
|
||||
}
|
|
@ -1,8 +1,6 @@
|
|||
using Microsoft.AspNetCore.Identity;
|
||||
|
||||
namespace DrinkRateAPI.DbEntities;
|
||||
|
||||
public class DbUserProfile
|
||||
public class DbUserProfile : DbEntityWithHistory
|
||||
{
|
||||
public Guid Id { get; set; }
|
||||
|
||||
|
@ -20,7 +18,7 @@ public class DbUserProfile
|
|||
public bool IsAdmin { get; set; }
|
||||
|
||||
public bool IsDeleted { get; set; }
|
||||
|
||||
|
||||
public Guid ApplicationUserId { get; set; }
|
||||
|
||||
public virtual DbApplicationUser ApplicationUser { get; set; }
|
||||
|
|
951
DrinkRateAPI/Migrations/20250809170131_ObjectHistory.Designer.cs
generated
Normal file
951
DrinkRateAPI/Migrations/20250809170131_ObjectHistory.Designer.cs
generated
Normal file
|
@ -0,0 +1,951 @@
|
|||
// <auto-generated />
|
||||
using System;
|
||||
using DrinkRateAPI.Contexts;
|
||||
using Microsoft.EntityFrameworkCore;
|
||||
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
|
||||
using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
|
||||
|
||||
#nullable disable
|
||||
|
||||
namespace DrinkRateAPI.Migrations
|
||||
{
|
||||
[DbContext(typeof(ApplicationDbContext))]
|
||||
[Migration("20250809170131_ObjectHistory")]
|
||||
partial class ObjectHistory
|
||||
{
|
||||
/// <inheritdoc />
|
||||
protected override void BuildTargetModel(ModelBuilder modelBuilder)
|
||||
{
|
||||
#pragma warning disable 612, 618
|
||||
modelBuilder
|
||||
.HasAnnotation("ProductVersion", "9.0.8")
|
||||
.HasAnnotation("Relational:MaxIdentifierLength", 63);
|
||||
|
||||
NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
|
||||
|
||||
modelBuilder.Entity("DbCompanyTableDbCompanyTableView", b =>
|
||||
{
|
||||
b.Property<Guid>("CompanyTablesId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("DbCompanyTableViewId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("CompanyTablesId", "DbCompanyTableViewId");
|
||||
|
||||
b.HasIndex("DbCompanyTableViewId");
|
||||
|
||||
b.ToTable("DbCompanyTableDbCompanyTableView");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DbCompanyTableViewDbUserProfile", b =>
|
||||
{
|
||||
b.Property<Guid>("CompanyTableViewsId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("UserProfilesId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("CompanyTableViewsId", "UserProfilesId");
|
||||
|
||||
b.HasIndex("UserProfilesId");
|
||||
|
||||
b.ToTable("DbCompanyTableViewDbUserProfile");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DbProductTableDbProductTableView", b =>
|
||||
{
|
||||
b.Property<Guid>("DbProductTableViewId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("ProductTablesId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("DbProductTableViewId", "ProductTablesId");
|
||||
|
||||
b.HasIndex("ProductTablesId");
|
||||
|
||||
b.ToTable("DbProductTableDbProductTableView");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DbProductTableViewDbUserProfile", b =>
|
||||
{
|
||||
b.Property<Guid>("ProductTableViewsId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("UserProfilesId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("ProductTableViewsId", "UserProfilesId");
|
||||
|
||||
b.HasIndex("UserProfilesId");
|
||||
|
||||
b.ToTable("DbProductTableViewDbUserProfile");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbApplicationUser", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<int>("AccessFailedCount")
|
||||
.HasColumnType("integer");
|
||||
|
||||
b.Property<string>("ConcurrencyStamp")
|
||||
.IsConcurrencyToken()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("Email")
|
||||
.HasMaxLength(256)
|
||||
.HasColumnType("character varying(256)");
|
||||
|
||||
b.Property<bool>("EmailConfirmed")
|
||||
.HasColumnType("boolean");
|
||||
|
||||
b.Property<bool>("LockoutEnabled")
|
||||
.HasColumnType("boolean");
|
||||
|
||||
b.Property<DateTimeOffset?>("LockoutEnd")
|
||||
.HasColumnType("timestamp with time zone");
|
||||
|
||||
b.Property<string>("NormalizedEmail")
|
||||
.HasMaxLength(256)
|
||||
.HasColumnType("character varying(256)");
|
||||
|
||||
b.Property<string>("NormalizedUserName")
|
||||
.HasMaxLength(256)
|
||||
.HasColumnType("character varying(256)");
|
||||
|
||||
b.Property<string>("PasswordHash")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("PhoneNumber")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<bool>("PhoneNumberConfirmed")
|
||||
.HasColumnType("boolean");
|
||||
|
||||
b.Property<string>("SecurityStamp")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<bool>("TwoFactorEnabled")
|
||||
.HasColumnType("boolean");
|
||||
|
||||
b.Property<string>("UserName")
|
||||
.HasMaxLength(256)
|
||||
.HasColumnType("character varying(256)");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("NormalizedEmail")
|
||||
.HasDatabaseName("EmailIndex");
|
||||
|
||||
b.HasIndex("NormalizedUserName")
|
||||
.IsUnique()
|
||||
.HasDatabaseName("UserNameIndex");
|
||||
|
||||
b.ToTable("AspNetUsers", (string)null);
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompany", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("CompanyName")
|
||||
.IsRequired()
|
||||
.HasMaxLength(50)
|
||||
.HasColumnType("character varying(50)");
|
||||
|
||||
b.Property<Guid>("CompanyTableId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<long>("RatingCount")
|
||||
.HasColumnType("bigint");
|
||||
|
||||
b.Property<long>("RatingSum")
|
||||
.HasColumnType("bigint");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("CompanyName")
|
||||
.IsUnique();
|
||||
|
||||
b.HasIndex("CompanyTableId");
|
||||
|
||||
b.ToTable("Companies");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyRating", b =>
|
||||
{
|
||||
b.Property<Guid>("UserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("CompanyId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("Comment")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<byte>("Rating")
|
||||
.HasColumnType("smallint");
|
||||
|
||||
b.HasKey("UserProfileId", "CompanyId");
|
||||
|
||||
b.HasIndex("CompanyId");
|
||||
|
||||
b.ToTable("CompanyRatings");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTable", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("CompanyTableName")
|
||||
.IsRequired()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("CompanyTableName")
|
||||
.IsUnique();
|
||||
|
||||
b.ToTable("CompanyTables");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTableView", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.ToTable("CompanyTableViews");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProduct", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("CompanyId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("ProductName")
|
||||
.IsRequired()
|
||||
.HasMaxLength(50)
|
||||
.HasColumnType("character varying(50)");
|
||||
|
||||
b.Property<Guid>("ProductTableId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<long>("RatingCount")
|
||||
.HasColumnType("bigint");
|
||||
|
||||
b.Property<long>("RatingSum")
|
||||
.HasColumnType("bigint");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("CompanyId");
|
||||
|
||||
b.HasIndex("ProductName")
|
||||
.IsUnique();
|
||||
|
||||
b.HasIndex("ProductTableId");
|
||||
|
||||
b.ToTable("Product");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductRating", b =>
|
||||
{
|
||||
b.Property<Guid>("UserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("ProductId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("Comment")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<byte>("Rating")
|
||||
.HasColumnType("smallint");
|
||||
|
||||
b.HasKey("UserProfileId", "ProductId");
|
||||
|
||||
b.HasIndex("ProductId");
|
||||
|
||||
b.ToTable("ProductRating");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductTable", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("ProductTableName")
|
||||
.IsRequired()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("ProductTableName")
|
||||
.IsUnique();
|
||||
|
||||
b.ToTable("ProductTable");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductTableView", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.ToTable("ProductTableView");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecord", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbCompanyId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbCompanyRatingCompanyId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbCompanyRatingUserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbCompanyTableViewId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbProductId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbProductRatingProductId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbProductRatingUserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbProductTableViewId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<DateTime>("UpdateTime")
|
||||
.HasColumnType("timestamp with time zone");
|
||||
|
||||
b.Property<Guid>("UserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("DbCompanyId");
|
||||
|
||||
b.HasIndex("DbCompanyTableViewId");
|
||||
|
||||
b.HasIndex("DbProductId");
|
||||
|
||||
b.HasIndex("DbProductTableViewId");
|
||||
|
||||
b.HasIndex("UserProfileId");
|
||||
|
||||
b.HasIndex("DbCompanyRatingUserProfileId", "DbCompanyRatingCompanyId");
|
||||
|
||||
b.HasIndex("DbProductRatingUserProfileId", "DbProductRatingProductId");
|
||||
|
||||
b.ToTable("UpdateRecords");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecordFieldChange", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbUpdateRecordId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("Field")
|
||||
.IsRequired()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("NewValue")
|
||||
.IsRequired()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("OldValue")
|
||||
.IsRequired()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("DbUpdateRecordId");
|
||||
|
||||
b.ToTable("UpdateRecordFieldChanges");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfile", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("ApplicationUserId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<bool>("IsAdmin")
|
||||
.HasColumnType("boolean");
|
||||
|
||||
b.Property<bool>("IsDeleted")
|
||||
.HasColumnType("boolean");
|
||||
|
||||
b.Property<string>("UserName")
|
||||
.IsRequired()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("ApplicationUserId")
|
||||
.IsUnique();
|
||||
|
||||
b.HasIndex("UserName")
|
||||
.IsUnique();
|
||||
|
||||
b.ToTable("UserProfiles");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfileCompanyTableStat", b =>
|
||||
{
|
||||
b.Property<Guid>("UserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("CompanyTableId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<int>("Credits")
|
||||
.HasColumnType("integer");
|
||||
|
||||
b.Property<int>("HighestRatingCount")
|
||||
.HasColumnType("integer");
|
||||
|
||||
b.Property<int>("RatingCount")
|
||||
.HasColumnType("integer");
|
||||
|
||||
b.HasKey("UserProfileId", "CompanyTableId");
|
||||
|
||||
b.HasIndex("CompanyTableId");
|
||||
|
||||
b.ToTable("UserProfileCompanyTableStats");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfileProductTableStat", b =>
|
||||
{
|
||||
b.Property<Guid>("UserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("ProductTableId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<int>("Credits")
|
||||
.HasColumnType("integer");
|
||||
|
||||
b.Property<int>("HighestRatingCount")
|
||||
.HasColumnType("integer");
|
||||
|
||||
b.Property<int>("RatingCount")
|
||||
.HasColumnType("integer");
|
||||
|
||||
b.HasKey("UserProfileId", "ProductTableId");
|
||||
|
||||
b.HasIndex("ProductTableId");
|
||||
|
||||
b.ToTable("UserProfileProductTableStats");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRole<System.Guid>", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("ConcurrencyStamp")
|
||||
.IsConcurrencyToken()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("Name")
|
||||
.HasMaxLength(256)
|
||||
.HasColumnType("character varying(256)");
|
||||
|
||||
b.Property<string>("NormalizedName")
|
||||
.HasMaxLength(256)
|
||||
.HasColumnType("character varying(256)");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("NormalizedName")
|
||||
.IsUnique()
|
||||
.HasDatabaseName("RoleNameIndex");
|
||||
|
||||
b.ToTable("AspNetRoles", (string)null);
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<System.Guid>", b =>
|
||||
{
|
||||
b.Property<int>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("integer");
|
||||
|
||||
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||
|
||||
b.Property<string>("ClaimType")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("ClaimValue")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<Guid>("RoleId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("RoleId");
|
||||
|
||||
b.ToTable("AspNetRoleClaims", (string)null);
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<System.Guid>", b =>
|
||||
{
|
||||
b.Property<int>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("integer");
|
||||
|
||||
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||
|
||||
b.Property<string>("ClaimType")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("ClaimValue")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<Guid>("UserId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("UserId");
|
||||
|
||||
b.ToTable("AspNetUserClaims", (string)null);
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<System.Guid>", b =>
|
||||
{
|
||||
b.Property<string>("LoginProvider")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("ProviderKey")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("ProviderDisplayName")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<Guid>("UserId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("LoginProvider", "ProviderKey");
|
||||
|
||||
b.HasIndex("UserId");
|
||||
|
||||
b.ToTable("AspNetUserLogins", (string)null);
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole<System.Guid>", b =>
|
||||
{
|
||||
b.Property<Guid>("UserId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid>("RoleId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("UserId", "RoleId");
|
||||
|
||||
b.HasIndex("RoleId");
|
||||
|
||||
b.ToTable("AspNetUserRoles", (string)null);
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<System.Guid>", b =>
|
||||
{
|
||||
b.Property<Guid>("UserId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("LoginProvider")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("Name")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("Value")
|
||||
.HasColumnType("text");
|
||||
|
||||
b.HasKey("UserId", "LoginProvider", "Name");
|
||||
|
||||
b.ToTable("AspNetUserTokens", (string)null);
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DbCompanyTableDbCompanyTableView", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTable", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("CompanyTablesId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTableView", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("DbCompanyTableViewId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DbCompanyTableViewDbUserProfile", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTableView", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("CompanyTableViewsId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUserProfile", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("UserProfilesId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DbProductTableDbProductTableView", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProductTableView", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("DbProductTableViewId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProductTable", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("ProductTablesId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DbProductTableViewDbUserProfile", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProductTableView", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("ProductTableViewsId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUserProfile", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("UserProfilesId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompany", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTable", "CompanyTable")
|
||||
.WithMany("Companies")
|
||||
.HasForeignKey("CompanyTableId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("CompanyTable");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyRating", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompany", "Company")
|
||||
.WithMany("CompanyRatings")
|
||||
.HasForeignKey("CompanyId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUserProfile", "UserProfile")
|
||||
.WithMany("CompanyRatings")
|
||||
.HasForeignKey("UserProfileId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("Company");
|
||||
|
||||
b.Navigation("UserProfile");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProduct", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompany", "Company")
|
||||
.WithMany("Products")
|
||||
.HasForeignKey("CompanyId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProductTable", "ProductTable")
|
||||
.WithMany("Products")
|
||||
.HasForeignKey("ProductTableId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("Company");
|
||||
|
||||
b.Navigation("ProductTable");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductRating", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProduct", "Product")
|
||||
.WithMany("ProductRatings")
|
||||
.HasForeignKey("ProductId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUserProfile", "UserProfile")
|
||||
.WithMany("ProductRatings")
|
||||
.HasForeignKey("UserProfileId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("Product");
|
||||
|
||||
b.Navigation("UserProfile");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecord", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompany", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbCompanyId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTableView", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbCompanyTableViewId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProduct", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbProductId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProductTableView", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbProductTableViewId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUserProfile", "UserProfile")
|
||||
.WithMany("History")
|
||||
.HasForeignKey("UserProfileId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyRating", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbCompanyRatingUserProfileId", "DbCompanyRatingCompanyId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProductRating", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbProductRatingUserProfileId", "DbProductRatingProductId");
|
||||
|
||||
b.Navigation("UserProfile");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecordFieldChange", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUpdateRecord", null)
|
||||
.WithMany("UpdateRecordFieldChanges")
|
||||
.HasForeignKey("DbUpdateRecordId");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfile", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbApplicationUser", "ApplicationUser")
|
||||
.WithOne("UserProfile")
|
||||
.HasForeignKey("DrinkRateAPI.DbEntities.DbUserProfile", "ApplicationUserId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("ApplicationUser");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfileCompanyTableStat", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTable", "CompanyTable")
|
||||
.WithMany()
|
||||
.HasForeignKey("CompanyTableId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUserProfile", "UserProfile")
|
||||
.WithMany("UserProfileCompanyTableStats")
|
||||
.HasForeignKey("UserProfileId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("CompanyTable");
|
||||
|
||||
b.Navigation("UserProfile");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfileProductTableStat", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProductTable", "ProductTable")
|
||||
.WithMany()
|
||||
.HasForeignKey("ProductTableId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUserProfile", "UserProfile")
|
||||
.WithMany("UserProfileProductTableStats")
|
||||
.HasForeignKey("UserProfileId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.Navigation("ProductTable");
|
||||
|
||||
b.Navigation("UserProfile");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim<System.Guid>", b =>
|
||||
{
|
||||
b.HasOne("Microsoft.AspNetCore.Identity.IdentityRole<System.Guid>", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("RoleId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim<System.Guid>", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbApplicationUser", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("UserId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin<System.Guid>", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbApplicationUser", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("UserId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole<System.Guid>", b =>
|
||||
{
|
||||
b.HasOne("Microsoft.AspNetCore.Identity.IdentityRole<System.Guid>", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("RoleId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbApplicationUser", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("UserId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken<System.Guid>", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbApplicationUser", null)
|
||||
.WithMany()
|
||||
.HasForeignKey("UserId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbApplicationUser", b =>
|
||||
{
|
||||
b.Navigation("UserProfile")
|
||||
.IsRequired();
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompany", b =>
|
||||
{
|
||||
b.Navigation("CompanyRatings");
|
||||
|
||||
b.Navigation("History");
|
||||
|
||||
b.Navigation("Products");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyRating", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTable", b =>
|
||||
{
|
||||
b.Navigation("Companies");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTableView", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProduct", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
|
||||
b.Navigation("ProductRatings");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductRating", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductTable", b =>
|
||||
{
|
||||
b.Navigation("Products");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductTableView", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecord", b =>
|
||||
{
|
||||
b.Navigation("UpdateRecordFieldChanges");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfile", b =>
|
||||
{
|
||||
b.Navigation("CompanyRatings");
|
||||
|
||||
b.Navigation("History");
|
||||
|
||||
b.Navigation("ProductRatings");
|
||||
|
||||
b.Navigation("UserProfileCompanyTableStats");
|
||||
|
||||
b.Navigation("UserProfileProductTableStats");
|
||||
});
|
||||
#pragma warning restore 612, 618
|
||||
}
|
||||
}
|
||||
}
|
142
DrinkRateAPI/Migrations/20250809170131_ObjectHistory.cs
Normal file
142
DrinkRateAPI/Migrations/20250809170131_ObjectHistory.cs
Normal file
|
@ -0,0 +1,142 @@
|
|||
using System;
|
||||
using Microsoft.EntityFrameworkCore.Migrations;
|
||||
|
||||
#nullable disable
|
||||
|
||||
namespace DrinkRateAPI.Migrations
|
||||
{
|
||||
/// <inheritdoc />
|
||||
public partial class ObjectHistory : Migration
|
||||
{
|
||||
/// <inheritdoc />
|
||||
protected override void Up(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
migrationBuilder.CreateTable(
|
||||
name: "UpdateRecords",
|
||||
columns: table => new
|
||||
{
|
||||
Id = table.Column<Guid>(type: "uuid", nullable: false),
|
||||
UserProfileId = table.Column<Guid>(type: "uuid", nullable: false),
|
||||
UpdateTime = table.Column<DateTime>(type: "timestamp with time zone", nullable: false),
|
||||
DbCompanyId = table.Column<Guid>(type: "uuid", nullable: true),
|
||||
DbCompanyRatingCompanyId = table.Column<Guid>(type: "uuid", nullable: true),
|
||||
DbCompanyRatingUserProfileId = table.Column<Guid>(type: "uuid", nullable: true),
|
||||
DbCompanyTableViewId = table.Column<Guid>(type: "uuid", nullable: true),
|
||||
DbProductId = table.Column<Guid>(type: "uuid", nullable: true),
|
||||
DbProductRatingProductId = table.Column<Guid>(type: "uuid", nullable: true),
|
||||
DbProductRatingUserProfileId = table.Column<Guid>(type: "uuid", nullable: true),
|
||||
DbProductTableViewId = table.Column<Guid>(type: "uuid", nullable: true)
|
||||
},
|
||||
constraints: table =>
|
||||
{
|
||||
table.PrimaryKey("PK_UpdateRecords", x => x.Id);
|
||||
table.ForeignKey(
|
||||
name: "FK_UpdateRecords_Companies_DbCompanyId",
|
||||
column: x => x.DbCompanyId,
|
||||
principalTable: "Companies",
|
||||
principalColumn: "Id");
|
||||
table.ForeignKey(
|
||||
name: "FK_UpdateRecords_CompanyRatings_DbCompanyRatingUserProfileId_D~",
|
||||
columns: x => new { x.DbCompanyRatingUserProfileId, x.DbCompanyRatingCompanyId },
|
||||
principalTable: "CompanyRatings",
|
||||
principalColumns: new[] { "UserProfileId", "CompanyId" });
|
||||
table.ForeignKey(
|
||||
name: "FK_UpdateRecords_CompanyTableViews_DbCompanyTableViewId",
|
||||
column: x => x.DbCompanyTableViewId,
|
||||
principalTable: "CompanyTableViews",
|
||||
principalColumn: "Id");
|
||||
table.ForeignKey(
|
||||
name: "FK_UpdateRecords_ProductRating_DbProductRatingUserProfileId_Db~",
|
||||
columns: x => new { x.DbProductRatingUserProfileId, x.DbProductRatingProductId },
|
||||
principalTable: "ProductRating",
|
||||
principalColumns: new[] { "UserProfileId", "ProductId" });
|
||||
table.ForeignKey(
|
||||
name: "FK_UpdateRecords_ProductTableView_DbProductTableViewId",
|
||||
column: x => x.DbProductTableViewId,
|
||||
principalTable: "ProductTableView",
|
||||
principalColumn: "Id");
|
||||
table.ForeignKey(
|
||||
name: "FK_UpdateRecords_Product_DbProductId",
|
||||
column: x => x.DbProductId,
|
||||
principalTable: "Product",
|
||||
principalColumn: "Id");
|
||||
table.ForeignKey(
|
||||
name: "FK_UpdateRecords_UserProfiles_UserProfileId",
|
||||
column: x => x.UserProfileId,
|
||||
principalTable: "UserProfiles",
|
||||
principalColumn: "Id",
|
||||
onDelete: ReferentialAction.Cascade);
|
||||
});
|
||||
|
||||
migrationBuilder.CreateTable(
|
||||
name: "UpdateRecordFieldChanges",
|
||||
columns: table => new
|
||||
{
|
||||
Id = table.Column<Guid>(type: "uuid", nullable: false),
|
||||
Field = table.Column<string>(type: "text", nullable: false),
|
||||
OldValue = table.Column<string>(type: "text", nullable: false),
|
||||
NewValue = table.Column<string>(type: "text", nullable: false),
|
||||
DbUpdateRecordId = table.Column<Guid>(type: "uuid", nullable: true)
|
||||
},
|
||||
constraints: table =>
|
||||
{
|
||||
table.PrimaryKey("PK_UpdateRecordFieldChanges", x => x.Id);
|
||||
table.ForeignKey(
|
||||
name: "FK_UpdateRecordFieldChanges_UpdateRecords_DbUpdateRecordId",
|
||||
column: x => x.DbUpdateRecordId,
|
||||
principalTable: "UpdateRecords",
|
||||
principalColumn: "Id");
|
||||
});
|
||||
|
||||
migrationBuilder.CreateIndex(
|
||||
name: "IX_UpdateRecordFieldChanges_DbUpdateRecordId",
|
||||
table: "UpdateRecordFieldChanges",
|
||||
column: "DbUpdateRecordId");
|
||||
|
||||
migrationBuilder.CreateIndex(
|
||||
name: "IX_UpdateRecords_DbCompanyId",
|
||||
table: "UpdateRecords",
|
||||
column: "DbCompanyId");
|
||||
|
||||
migrationBuilder.CreateIndex(
|
||||
name: "IX_UpdateRecords_DbCompanyRatingUserProfileId_DbCompanyRatingC~",
|
||||
table: "UpdateRecords",
|
||||
columns: new[] { "DbCompanyRatingUserProfileId", "DbCompanyRatingCompanyId" });
|
||||
|
||||
migrationBuilder.CreateIndex(
|
||||
name: "IX_UpdateRecords_DbCompanyTableViewId",
|
||||
table: "UpdateRecords",
|
||||
column: "DbCompanyTableViewId");
|
||||
|
||||
migrationBuilder.CreateIndex(
|
||||
name: "IX_UpdateRecords_DbProductId",
|
||||
table: "UpdateRecords",
|
||||
column: "DbProductId");
|
||||
|
||||
migrationBuilder.CreateIndex(
|
||||
name: "IX_UpdateRecords_DbProductRatingUserProfileId_DbProductRatingP~",
|
||||
table: "UpdateRecords",
|
||||
columns: new[] { "DbProductRatingUserProfileId", "DbProductRatingProductId" });
|
||||
|
||||
migrationBuilder.CreateIndex(
|
||||
name: "IX_UpdateRecords_DbProductTableViewId",
|
||||
table: "UpdateRecords",
|
||||
column: "DbProductTableViewId");
|
||||
|
||||
migrationBuilder.CreateIndex(
|
||||
name: "IX_UpdateRecords_UserProfileId",
|
||||
table: "UpdateRecords",
|
||||
column: "UserProfileId");
|
||||
}
|
||||
|
||||
/// <inheritdoc />
|
||||
protected override void Down(MigrationBuilder migrationBuilder)
|
||||
{
|
||||
migrationBuilder.DropTable(
|
||||
name: "UpdateRecordFieldChanges");
|
||||
|
||||
migrationBuilder.DropTable(
|
||||
name: "UpdateRecords");
|
||||
}
|
||||
}
|
||||
}
|
|
@ -312,6 +312,89 @@ namespace DrinkRateAPI.Migrations
|
|||
b.ToTable("ProductTableView");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecord", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbCompanyId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbCompanyRatingCompanyId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbCompanyRatingUserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbCompanyTableViewId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbProductId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbProductRatingProductId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbProductRatingUserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbProductTableViewId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<DateTime>("UpdateTime")
|
||||
.HasColumnType("timestamp with time zone");
|
||||
|
||||
b.Property<Guid>("UserProfileId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("DbCompanyId");
|
||||
|
||||
b.HasIndex("DbCompanyTableViewId");
|
||||
|
||||
b.HasIndex("DbProductId");
|
||||
|
||||
b.HasIndex("DbProductTableViewId");
|
||||
|
||||
b.HasIndex("UserProfileId");
|
||||
|
||||
b.HasIndex("DbCompanyRatingUserProfileId", "DbCompanyRatingCompanyId");
|
||||
|
||||
b.HasIndex("DbProductRatingUserProfileId", "DbProductRatingProductId");
|
||||
|
||||
b.ToTable("UpdateRecords");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecordFieldChange", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
.ValueGeneratedOnAdd()
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<Guid?>("DbUpdateRecordId")
|
||||
.HasColumnType("uuid");
|
||||
|
||||
b.Property<string>("Field")
|
||||
.IsRequired()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("NewValue")
|
||||
.IsRequired()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.Property<string>("OldValue")
|
||||
.IsRequired()
|
||||
.HasColumnType("text");
|
||||
|
||||
b.HasKey("Id");
|
||||
|
||||
b.HasIndex("DbUpdateRecordId");
|
||||
|
||||
b.ToTable("UpdateRecordFieldChanges");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfile", b =>
|
||||
{
|
||||
b.Property<Guid>("Id")
|
||||
|
@ -648,6 +731,48 @@ namespace DrinkRateAPI.Migrations
|
|||
b.Navigation("UserProfile");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecord", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompany", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbCompanyId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTableView", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbCompanyTableViewId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProduct", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbProductId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProductTableView", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbProductTableViewId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUserProfile", "UserProfile")
|
||||
.WithMany("History")
|
||||
.HasForeignKey("UserProfileId")
|
||||
.OnDelete(DeleteBehavior.Cascade)
|
||||
.IsRequired();
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyRating", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbCompanyRatingUserProfileId", "DbCompanyRatingCompanyId");
|
||||
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbProductRating", null)
|
||||
.WithMany("History")
|
||||
.HasForeignKey("DbProductRatingUserProfileId", "DbProductRatingProductId");
|
||||
|
||||
b.Navigation("UserProfile");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecordFieldChange", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbUpdateRecord", null)
|
||||
.WithMany("UpdateRecordFieldChanges")
|
||||
.HasForeignKey("DbUpdateRecordId");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfile", b =>
|
||||
{
|
||||
b.HasOne("DrinkRateAPI.DbEntities.DbApplicationUser", "ApplicationUser")
|
||||
|
@ -758,28 +883,59 @@ namespace DrinkRateAPI.Migrations
|
|||
{
|
||||
b.Navigation("CompanyRatings");
|
||||
|
||||
b.Navigation("History");
|
||||
|
||||
b.Navigation("Products");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyRating", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTable", b =>
|
||||
{
|
||||
b.Navigation("Companies");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTableView", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProduct", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
|
||||
b.Navigation("ProductRatings");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductRating", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductTable", b =>
|
||||
{
|
||||
b.Navigation("Products");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductTableView", b =>
|
||||
{
|
||||
b.Navigation("History");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecord", b =>
|
||||
{
|
||||
b.Navigation("UpdateRecordFieldChanges");
|
||||
});
|
||||
|
||||
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUserProfile", b =>
|
||||
{
|
||||
b.Navigation("CompanyRatings");
|
||||
|
||||
b.Navigation("History");
|
||||
|
||||
b.Navigation("ProductRatings");
|
||||
|
||||
b.Navigation("UserProfileCompanyTableStats");
|
||||
|
|
Loading…
Reference in a new issue