Compare commits

..

No commits in common. "250811_ProductCompanyTable" and "main" have entirely different histories.

26 changed files with 11 additions and 3467 deletions

View file

@ -1,8 +0,0 @@
namespace DrinkRateAPI.ApiModels.CompanyTable;
public class CompanyTableGet
{
public string CompanyTableName { get; set; }
public string CompanyTableId { get; set; }
public string ProductTableId { get; set; }
}

View file

@ -1,7 +0,0 @@
namespace DrinkRateAPI.ApiModels.ProductCompanyTableCouple;
public class ProductCompanyTableCouplePost
{
public string ProductTableName { get; set; }
public string CompanyTableName { get; set; }
}

View file

@ -1,9 +0,0 @@
namespace DrinkRateAPI.ApiModels.ProductCompanyTableCouple;
public class ProductCompanyTableCouplePostResponse
{
public string ProductTableName { get; set; }
public string ProductTableId { get; set; }
public string CompanyTableName { get; set; }
public string CompanyTableId { get; set; }
}

View file

@ -1,8 +0,0 @@
namespace DrinkRateAPI.ApiModels.ProductTable;
public class ProductTableGet
{
public string ProductTableName { get; set; }
public string ProductTableId { get; set; }
public string CompanyTableId { get; set; }
}

View file

@ -1,5 +1,4 @@
using DrinkRateAPI.DbEntities; using DrinkRateAPI.DbEntities;
using DrinkRateAPI.Exceptions;
using DrinkRateAPI.Services; using DrinkRateAPI.Services;
namespace DrinkRateAPI.AuthorizationPolicies; namespace DrinkRateAPI.AuthorizationPolicies;
@ -27,16 +26,7 @@ public class AdminOnlyHandler : AuthorizationHandler<AdminOnlyRequirement>
AuthorizationHandlerContext context, AuthorizationHandlerContext context,
AdminOnlyRequirement requirement) AdminOnlyRequirement requirement)
{ {
DbUserProfile userProfile; var userProfile = await _applicationUserService.UserProfileByApplicationUserAsync(context.User);
try
{
userProfile = await _applicationUserService.UserProfileByApplicationUserAsync(context.User);
}
catch (NotFoundException _)
{
throw new ForbiddenException("You need to be logged in to do this action.");
}
if (_userProfileService.IsUserProfileAdmin(userProfile)) if (_userProfileService.IsUserProfileAdmin(userProfile))
{ {

View file

@ -1,7 +0,0 @@
namespace DrinkRateAPI.AuthorizationPolicies;
public static class PolicyConstants
{
public const string AdminOnly = "AdminOnly";
}

View file

@ -9,7 +9,7 @@ public class ApplicationDbContext : IdentityDbContext<DbApplicationUser, Identit
{ {
public DbSet<DbCompany> Companies { get; set; } public DbSet<DbCompany> Companies { get; set; }
public DbSet<DbCompanyRating> CompanyRatings { get; set; } public DbSet<DbCompanyRating> CompanyRatings { get; set; }
public DbSet<DbCompanyTable> CompanyTable { get; set; } public DbSet<DbCompanyTable> CompanyTables { get; set; }
public DbSet<DbCompanyTableView> CompanyTableViews { get; set; } public DbSet<DbCompanyTableView> CompanyTableViews { get; set; }
public DbSet<DbProduct> Product { get; set; } public DbSet<DbProduct> Product { get; set; }
@ -85,10 +85,6 @@ public class ApplicationDbContext : IdentityDbContext<DbApplicationUser, Identit
entity.HasIndex(ct => ct.CompanyTableName) entity.HasIndex(ct => ct.CompanyTableName)
.IsUnique(); .IsUnique();
entity.HasOne(ct => ct.ProductTable)
.WithOne(pt => pt.CompanyTable)
.HasForeignKey<DbProductTable>(pt => pt.CompanyTableId);
}); });
// Company Table View // Company Table View

View file

@ -1,24 +0,0 @@
using DrinkRateAPI.ApiModels.CompanyTable;
using DrinkRateAPI.Services;
using Microsoft.AspNetCore.Mvc;
namespace DrinkRateAPI.Controllers;
[ApiController]
[Route("companyTables")]
public class CompanyTableController : ControllerBase
{
private CompanyTableService _companyTableService;
public CompanyTableController(CompanyTableService companyTableService)
{
_companyTableService = companyTableService;
}
[HttpGet("{companyTableName}")]
[Produces("application/json")]
public async Task<CompanyTableGet> GetCompanyTable([FromRoute] string companyTableName)
{
return await _companyTableService.GetCompanyTable(companyTableName);
}
}

View file

@ -1,28 +0,0 @@
using DrinkRateAPI.ApiModels.ProductCompanyTableCouple;
using DrinkRateAPI.AuthorizationPolicies;
using DrinkRateAPI.Services;
using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc;
namespace DrinkRateAPI.Controllers;
[ApiController]
[Route("productCompanyTableCouple")]
public class ProductCompanyTableCoupleController : ControllerBase
{
private ProductCompanyTableCoupleService _productCompanyTableCoupleService;
public ProductCompanyTableCoupleController(ProductCompanyTableCoupleService productCompanyTableCoupleService)
{
_productCompanyTableCoupleService = productCompanyTableCoupleService;
}
[HttpPost]
[Authorize(Policy = PolicyConstants.AdminOnly)]
[Produces("application/json")]
public async Task<ProductCompanyTableCouplePostResponse> PostProductCompanyTableCouple(
[FromBody] ProductCompanyTableCouplePost productCompanyTableCouple)
{
return await _productCompanyTableCoupleService.PostProductCompanyTableCoupleAsync(productCompanyTableCouple);
}
}

View file

@ -1,25 +0,0 @@
using DrinkRateAPI.ApiModels.ProductTable;
using DrinkRateAPI.Services;
using Microsoft.AspNetCore.Mvc;
namespace DrinkRateAPI.Controllers;
[ApiController]
[Route("productTables")]
public class ProductTableController : ControllerBase
{
private ProductTableService _productTableService;
public ProductTableController(ProductTableService productTableService)
{
_productTableService = productTableService;
}
[HttpGet("{productTableName}")]
[Produces("application/json")]
public async Task<ProductTableGet> GetProductTable([FromRoute] string productTableName)
{
return await _productTableService.GetProductTable(productTableName);
}
}

View file

@ -1,5 +1,4 @@
using DrinkRateAPI.ApiModels.UserProfile; using DrinkRateAPI.ApiModels.UserProfile;
using DrinkRateAPI.AuthorizationPolicies;
using DrinkRateAPI.Services; using DrinkRateAPI.Services;
using Microsoft.AspNetCore.Authorization; using Microsoft.AspNetCore.Authorization;
using Microsoft.AspNetCore.Mvc; using Microsoft.AspNetCore.Mvc;
@ -32,7 +31,7 @@ public class UserProfileController : ControllerBase
} }
[HttpPut("{userId}")] [HttpPut("{userId}")]
[Authorize(Policy = PolicyConstants.AdminOnly)] [Authorize(Policy = "AdminOnly")]
[Produces("application/json")] [Produces("application/json")]
public async Task<UserProfileGet> PutUserProfile(string userId, [FromBody] UserProfilePut userProfile) public async Task<UserProfileGet> PutUserProfile(string userId, [FromBody] UserProfilePut userProfile)
{ {
@ -40,7 +39,7 @@ public class UserProfileController : ControllerBase
} }
[HttpGet("{userId}")] [HttpGet("{userId}")]
[Authorize(Policy = PolicyConstants.AdminOnly)] [Authorize(Policy = "AdminOnly")]
[Produces("application/json")] [Produces("application/json")]
public async Task<UserProfileGet> GetUserProfile(string userId) public async Task<UserProfileGet> GetUserProfile(string userId)
{ {

View file

@ -7,6 +7,4 @@ public class DbCompanyTable
public ICollection<DbCompany> Companies { get; set; } public ICollection<DbCompany> Companies { get; set; }
public string CompanyTableName { get; set; } public string CompanyTableName { get; set; }
public DbProductTable ProductTable { get; set; }
} }

View file

@ -7,7 +7,4 @@ public class DbProductTable
public ICollection<DbProduct> Products { get; set; } public ICollection<DbProduct> Products { get; set; }
public string ProductTableName { get; set; } public string ProductTableName { get; set; }
public Guid CompanyTableId { get; set; }
public DbCompanyTable CompanyTable { get; set; }
} }

View file

@ -20,6 +20,7 @@
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<Folder Include="ApiModels\" />
<Folder Include="Migrations\" /> <Folder Include="Migrations\" />
</ItemGroup> </ItemGroup>

View file

@ -30,9 +30,10 @@ public class ExceptionHandlingMiddleware
private async Task HandleExceptionAsync(HttpContext context, Exception exception) private async Task HandleExceptionAsync(HttpContext context, Exception exception)
{ {
_logger.LogError(exception, "An error occurred."); _logger.LogError(exception, "An unexpected error occurred.");
var defaultResponse = exception switch
var response = exception switch
{ {
BadRequestException _ => new ExceptionResponse(StatusCodes.Status400BadRequest, "Application exception occurred."), BadRequestException _ => new ExceptionResponse(StatusCodes.Status400BadRequest, "Application exception occurred."),
NotFoundException _ => new ExceptionResponse(StatusCodes.Status404NotFound, "The request key not found."), NotFoundException _ => new ExceptionResponse(StatusCodes.Status404NotFound, "The request key not found."),
@ -44,12 +45,6 @@ public class ExceptionHandlingMiddleware
_ => new ExceptionResponse(StatusCodes.Status500InternalServerError, "Internal server error. Please retry later.") _ => new ExceptionResponse(StatusCodes.Status500InternalServerError, "Internal server error. Please retry later.")
}; };
var description = !string.IsNullOrWhiteSpace(exception.Message)
? exception.Message
: defaultResponse.Description;
var response = defaultResponse with { Description = description };
context.Response.ContentType = "application/json"; context.Response.ContentType = "application/json";
context.Response.StatusCode = response.StatusCode; context.Response.StatusCode = response.StatusCode;
await context.Response.WriteAsJsonAsync(response); await context.Response.WriteAsJsonAsync(response);

View file

@ -1,974 +0,0 @@
// <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("20250811180050_ProductCompanyTableBinding")]
partial class ProductCompanyTableBinding
{
/// <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.Property<Guid>("ProductTableId")
.HasColumnType("uuid");
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<Guid>("CompanyTableId")
.HasColumnType("uuid");
b.Property<string>("ProductTableName")
.IsRequired()
.HasColumnType("text");
b.HasKey("Id");
b.HasIndex("CompanyTableId")
.IsUnique();
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.DbProductTable", b =>
{
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTable", "CompanyTable")
.WithOne("ProductTable")
.HasForeignKey("DrinkRateAPI.DbEntities.DbProductTable", "CompanyTableId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("CompanyTable");
});
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");
b.Navigation("ProductTable")
.IsRequired();
});
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
}
}
}

View file

@ -1,63 +0,0 @@
using System;
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace DrinkRateAPI.Migrations
{
/// <inheritdoc />
public partial class ProductCompanyTableBinding : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.AddColumn<Guid>(
name: "CompanyTableId",
table: "ProductTable",
type: "uuid",
nullable: false,
defaultValue: new Guid("00000000-0000-0000-0000-000000000000"));
migrationBuilder.AddColumn<Guid>(
name: "ProductTableId",
table: "CompanyTables",
type: "uuid",
nullable: false,
defaultValue: new Guid("00000000-0000-0000-0000-000000000000"));
migrationBuilder.CreateIndex(
name: "IX_ProductTable_CompanyTableId",
table: "ProductTable",
column: "CompanyTableId",
unique: true);
migrationBuilder.AddForeignKey(
name: "FK_ProductTable_CompanyTables_CompanyTableId",
table: "ProductTable",
column: "CompanyTableId",
principalTable: "CompanyTables",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_ProductTable_CompanyTables_CompanyTableId",
table: "ProductTable");
migrationBuilder.DropIndex(
name: "IX_ProductTable_CompanyTableId",
table: "ProductTable");
migrationBuilder.DropColumn(
name: "CompanyTableId",
table: "ProductTable");
migrationBuilder.DropColumn(
name: "ProductTableId",
table: "CompanyTables");
}
}
}

View file

@ -1,974 +0,0 @@
// <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("20250811181117_FixTypo")]
partial class FixTypo
{
/// <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.Property<Guid>("ProductTableId")
.HasColumnType("uuid");
b.HasKey("Id");
b.HasIndex("CompanyTableName")
.IsUnique();
b.ToTable("CompanyTable");
});
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<Guid>("CompanyTableId")
.HasColumnType("uuid");
b.Property<string>("ProductTableName")
.IsRequired()
.HasColumnType("text");
b.HasKey("Id");
b.HasIndex("CompanyTableId")
.IsUnique();
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.DbProductTable", b =>
{
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTable", "CompanyTable")
.WithOne("ProductTable")
.HasForeignKey("DrinkRateAPI.DbEntities.DbProductTable", "CompanyTableId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("CompanyTable");
});
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");
b.Navigation("ProductTable")
.IsRequired();
});
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
}
}
}

View file

@ -1,150 +0,0 @@
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace DrinkRateAPI.Migrations
{
/// <inheritdoc />
public partial class FixTypo : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_Companies_CompanyTables_CompanyTableId",
table: "Companies");
migrationBuilder.DropForeignKey(
name: "FK_DbCompanyTableDbCompanyTableView_CompanyTables_CompanyTable~",
table: "DbCompanyTableDbCompanyTableView");
migrationBuilder.DropForeignKey(
name: "FK_ProductTable_CompanyTables_CompanyTableId",
table: "ProductTable");
migrationBuilder.DropForeignKey(
name: "FK_UserProfileCompanyTableStats_CompanyTables_CompanyTableId",
table: "UserProfileCompanyTableStats");
migrationBuilder.DropPrimaryKey(
name: "PK_CompanyTables",
table: "CompanyTables");
migrationBuilder.RenameTable(
name: "CompanyTables",
newName: "CompanyTable");
migrationBuilder.RenameIndex(
name: "IX_CompanyTables_CompanyTableName",
table: "CompanyTable",
newName: "IX_CompanyTable_CompanyTableName");
migrationBuilder.AddPrimaryKey(
name: "PK_CompanyTable",
table: "CompanyTable",
column: "Id");
migrationBuilder.AddForeignKey(
name: "FK_Companies_CompanyTable_CompanyTableId",
table: "Companies",
column: "CompanyTableId",
principalTable: "CompanyTable",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_DbCompanyTableDbCompanyTableView_CompanyTable_CompanyTables~",
table: "DbCompanyTableDbCompanyTableView",
column: "CompanyTablesId",
principalTable: "CompanyTable",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_ProductTable_CompanyTable_CompanyTableId",
table: "ProductTable",
column: "CompanyTableId",
principalTable: "CompanyTable",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_UserProfileCompanyTableStats_CompanyTable_CompanyTableId",
table: "UserProfileCompanyTableStats",
column: "CompanyTableId",
principalTable: "CompanyTable",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_Companies_CompanyTable_CompanyTableId",
table: "Companies");
migrationBuilder.DropForeignKey(
name: "FK_DbCompanyTableDbCompanyTableView_CompanyTable_CompanyTables~",
table: "DbCompanyTableDbCompanyTableView");
migrationBuilder.DropForeignKey(
name: "FK_ProductTable_CompanyTable_CompanyTableId",
table: "ProductTable");
migrationBuilder.DropForeignKey(
name: "FK_UserProfileCompanyTableStats_CompanyTable_CompanyTableId",
table: "UserProfileCompanyTableStats");
migrationBuilder.DropPrimaryKey(
name: "PK_CompanyTable",
table: "CompanyTable");
migrationBuilder.RenameTable(
name: "CompanyTable",
newName: "CompanyTables");
migrationBuilder.RenameIndex(
name: "IX_CompanyTable_CompanyTableName",
table: "CompanyTables",
newName: "IX_CompanyTables_CompanyTableName");
migrationBuilder.AddPrimaryKey(
name: "PK_CompanyTables",
table: "CompanyTables",
column: "Id");
migrationBuilder.AddForeignKey(
name: "FK_Companies_CompanyTables_CompanyTableId",
table: "Companies",
column: "CompanyTableId",
principalTable: "CompanyTables",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_DbCompanyTableDbCompanyTableView_CompanyTables_CompanyTable~",
table: "DbCompanyTableDbCompanyTableView",
column: "CompanyTablesId",
principalTable: "CompanyTables",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_ProductTable_CompanyTables_CompanyTableId",
table: "ProductTable",
column: "CompanyTableId",
principalTable: "CompanyTables",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
migrationBuilder.AddForeignKey(
name: "FK_UserProfileCompanyTableStats_CompanyTables_CompanyTableId",
table: "UserProfileCompanyTableStats",
column: "CompanyTableId",
principalTable: "CompanyTables",
principalColumn: "Id",
onDelete: ReferentialAction.Cascade);
}
}
}

View file

@ -1,971 +0,0 @@
// <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("20250811190023_FixProductCompanyTableBinding")]
partial class FixProductCompanyTableBinding
{
/// <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("CompanyTable");
});
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<Guid>("CompanyTableId")
.HasColumnType("uuid");
b.Property<string>("ProductTableName")
.IsRequired()
.HasColumnType("text");
b.HasKey("Id");
b.HasIndex("CompanyTableId")
.IsUnique();
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.DbProductTable", b =>
{
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTable", "CompanyTable")
.WithOne("ProductTable")
.HasForeignKey("DrinkRateAPI.DbEntities.DbProductTable", "CompanyTableId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("CompanyTable");
});
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");
b.Navigation("ProductTable")
.IsRequired();
});
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
}
}
}

View file

@ -1,30 +0,0 @@
using System;
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace DrinkRateAPI.Migrations
{
/// <inheritdoc />
public partial class FixProductCompanyTableBinding : Migration
{
/// <inheritdoc />
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropColumn(
name: "ProductTableId",
table: "CompanyTable");
}
/// <inheritdoc />
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.AddColumn<Guid>(
name: "ProductTableId",
table: "CompanyTable",
type: "uuid",
nullable: false,
defaultValue: new Guid("00000000-0000-0000-0000-000000000000"));
}
}
}

View file

@ -213,7 +213,7 @@ namespace DrinkRateAPI.Migrations
b.HasIndex("CompanyTableName") b.HasIndex("CompanyTableName")
.IsUnique(); .IsUnique();
b.ToTable("CompanyTable"); b.ToTable("CompanyTables");
}); });
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTableView", b => modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTableView", b =>
@ -289,18 +289,12 @@ namespace DrinkRateAPI.Migrations
.ValueGeneratedOnAdd() .ValueGeneratedOnAdd()
.HasColumnType("uuid"); .HasColumnType("uuid");
b.Property<Guid>("CompanyTableId")
.HasColumnType("uuid");
b.Property<string>("ProductTableName") b.Property<string>("ProductTableName")
.IsRequired() .IsRequired()
.HasColumnType("text"); .HasColumnType("text");
b.HasKey("Id"); b.HasKey("Id");
b.HasIndex("CompanyTableId")
.IsUnique();
b.HasIndex("ProductTableName") b.HasIndex("ProductTableName")
.IsUnique(); .IsUnique();
@ -737,17 +731,6 @@ namespace DrinkRateAPI.Migrations
b.Navigation("UserProfile"); b.Navigation("UserProfile");
}); });
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbProductTable", b =>
{
b.HasOne("DrinkRateAPI.DbEntities.DbCompanyTable", "CompanyTable")
.WithOne("ProductTable")
.HasForeignKey("DrinkRateAPI.DbEntities.DbProductTable", "CompanyTableId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("CompanyTable");
});
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecord", b => modelBuilder.Entity("DrinkRateAPI.DbEntities.DbUpdateRecord", b =>
{ {
b.HasOne("DrinkRateAPI.DbEntities.DbCompany", null) b.HasOne("DrinkRateAPI.DbEntities.DbCompany", null)
@ -913,9 +896,6 @@ namespace DrinkRateAPI.Migrations
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTable", b => modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTable", b =>
{ {
b.Navigation("Companies"); b.Navigation("Companies");
b.Navigation("ProductTable")
.IsRequired();
}); });
modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTableView", b => modelBuilder.Entity("DrinkRateAPI.DbEntities.DbCompanyTableView", b =>

View file

@ -15,7 +15,7 @@ builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle // Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer(); builder.Services.AddEndpointsApiExplorer();
builder.Services.AddAuthorizationBuilder() builder.Services.AddAuthorizationBuilder()
.AddPolicy(PolicyConstants.AdminOnly, policy => .AddPolicy("AdminOnly", policy =>
policy.Requirements.Add(new AdminOnlyRequirement())); policy.Requirements.Add(new AdminOnlyRequirement()));
builder.Services.AddIdentityApiEndpoints<DbApplicationUser>() builder.Services.AddIdentityApiEndpoints<DbApplicationUser>()
.AddEntityFrameworkStores<ApplicationDbContext>(); .AddEntityFrameworkStores<ApplicationDbContext>();
@ -58,9 +58,6 @@ builder.Services.AddSwaggerGen(c =>
builder.Services.AddDbContext<ApplicationDbContext>(); builder.Services.AddDbContext<ApplicationDbContext>();
builder.Services.AddScoped<ApplicationUserService>(); builder.Services.AddScoped<ApplicationUserService>();
builder.Services.AddScoped<UserProfileService>(); builder.Services.AddScoped<UserProfileService>();
builder.Services.AddScoped<ProductTableService>();
builder.Services.AddScoped<CompanyTableService>();
builder.Services.AddScoped<ProductCompanyTableCoupleService>();
var app = builder.Build(); var app = builder.Build();

View file

@ -1,38 +0,0 @@
using DrinkRateAPI.ApiModels.CompanyTable;
using DrinkRateAPI.Contexts;
using DrinkRateAPI.Exceptions;
using Microsoft.EntityFrameworkCore;
namespace DrinkRateAPI.Services;
public class CompanyTableService(ApplicationDbContext context)
{
private ApplicationDbContext _context = context;
public async Task<CompanyTableGet> GetCompanyTable(string companyTableName)
{
if (string.IsNullOrWhiteSpace(companyTableName))
{
throw new BadRequestException("Company table name cannot be null or empty.");
}
try
{
var companyTable =
await _context.CompanyTable.Include(dbCompanyTable => dbCompanyTable.ProductTable)
.FirstOrDefaultAsync(x => x.CompanyTableName == companyTableName) ??
throw new NotFoundException($"Company table with the name {companyTableName} not found.");
return new CompanyTableGet
{
CompanyTableName = companyTable.CompanyTableName,
CompanyTableId = companyTable.Id.ToString(),
ProductTableId = companyTable.ProductTable.Id.ToString(),
};
}
catch (ArgumentNullException _)
{
throw new BadRequestException("Company table name cannot be null or empty.");
}
}
}

View file

@ -1,66 +0,0 @@
using DrinkRateAPI.ApiModels.ProductCompanyTableCouple;
using DrinkRateAPI.ApiModels.ProductTable;
using DrinkRateAPI.Contexts;
using DrinkRateAPI.DbEntities;
using DrinkRateAPI.Exceptions;
using Microsoft.EntityFrameworkCore;
using Npgsql;
namespace DrinkRateAPI.Services;
public class ProductCompanyTableCoupleService(ApplicationDbContext context)
{
private ApplicationDbContext _context = context;
public async Task<ProductCompanyTableCouplePostResponse> PostProductCompanyTableCoupleAsync(
ProductCompanyTableCouplePost productCompanyTableCouplePost)
{
var companyTable = new DbCompanyTable
{
CompanyTableName = productCompanyTableCouplePost.CompanyTableName,
ProductTable = new DbProductTable
{
ProductTableName = productCompanyTableCouplePost.ProductTableName
}
};
_context.CompanyTable.Add(companyTable);
try
{
await _context.SaveChangesAsync();
}
catch (DbUpdateException ex) when
(ex.InnerException is PostgresException
{
SqlState: PostgresErrorCodes.UniqueViolation
}
)
{
throw new BadRequestException("Product table or company table with the same name already exists.");
}
return await GetProductCompanyTableCouplePostResponse(
productCompanyTableCouplePost.ProductTableName,
productCompanyTableCouplePost.CompanyTableName);
}
private async Task<ProductCompanyTableCouplePostResponse> GetProductCompanyTableCouplePostResponse(
string productTableName, string companyTableName)
{
var productTable =
await _context.ProductTable.FirstOrDefaultAsync(x => x.ProductTableName == productTableName) ??
throw new NotFoundException();
var companyTable =
await _context.CompanyTable.FirstOrDefaultAsync(x => x.CompanyTableName == companyTableName) ??
throw new NotFoundException();
return new ProductCompanyTableCouplePostResponse
{
ProductTableName = productTable.ProductTableName,
ProductTableId = productTable.Id.ToString(),
CompanyTableName = companyTable.CompanyTableName,
CompanyTableId = companyTable.Id.ToString()
};
}
}

View file

@ -1,27 +0,0 @@
using DrinkRateAPI.ApiModels.ProductTable;
using DrinkRateAPI.Contexts;
using DrinkRateAPI.DbEntities;
using DrinkRateAPI.Exceptions;
using Microsoft.EntityFrameworkCore;
namespace DrinkRateAPI.Services;
public class ProductTableService(ApplicationDbContext context)
{
private ApplicationDbContext _context = context;
public async Task<ProductTableGet> GetProductTable(string productTableName)
{
var productTable =
await _context.ProductTable.FirstOrDefaultAsync(x => x.ProductTableName == productTableName) ??
throw new NotFoundException($"Product table with the name {productTableName} not found.");
return new ProductTableGet
{
ProductTableName = productTable.ProductTableName,
ProductTableId = productTable.Id.ToString(),
CompanyTableId = productTable.CompanyTableId.ToString(),
};
}
}