Files
Pibd-21_Semin_D.A._SmallSof…/SmallSoftwareProject/SmallSoftwareDatabase/Migrations/SmallSoftwareDbContextModelSnapshot.cs
2025-04-17 22:57:21 +04:00

343 lines
12 KiB
C#

// <auto-generated />
using System;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
using SmallSoftwareDatabase;
#nullable disable
namespace SmallSoftwareDatabase.Migrations
{
[DbContext(typeof(SmallSoftwareDbContext))]
partial class SmallSoftwareDbContextModelSnapshot : ModelSnapshot
{
protected override void BuildModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "9.0.2")
.HasAnnotation("Relational:MaxIdentifierLength", 63);
NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
modelBuilder.Entity("SmallSoftwareDatabase.Models.InstallationRequest", b =>
{
b.Property<string>("RequestId")
.HasColumnType("text");
b.Property<string>("SoftwareId")
.HasColumnType("text");
b.Property<int>("Count")
.HasColumnType("integer");
b.Property<double>("Price")
.HasColumnType("double precision");
b.HasKey("RequestId", "SoftwareId");
b.HasIndex("SoftwareId");
b.ToTable("InstallationRequests");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Manufacturer", b =>
{
b.Property<string>("Id")
.HasColumnType("text");
b.Property<string>("ManufacturerName")
.IsRequired()
.HasColumnType("text");
b.Property<string>("PrevManufacturerName")
.HasColumnType("text");
b.Property<string>("PrevPrevManufacturerName")
.HasColumnType("text");
b.HasKey("Id");
b.HasIndex("ManufacturerName")
.IsUnique();
b.ToTable("Manufacturers");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Post", b =>
{
b.Property<string>("Id")
.HasColumnType("text");
b.Property<DateTime>("ChangeDate")
.HasColumnType("timestamp without time zone");
b.Property<bool>("IsActual")
.HasColumnType("boolean");
b.Property<string>("PostId")
.IsRequired()
.HasColumnType("text");
b.Property<string>("PostName")
.IsRequired()
.HasColumnType("text");
b.Property<int>("PostType")
.HasColumnType("integer");
b.Property<double>("Salary")
.HasColumnType("double precision");
b.HasKey("Id");
b.HasIndex("PostId", "IsActual")
.IsUnique()
.HasFilter("\"IsActual\" = TRUE");
b.HasIndex("PostName", "IsActual")
.IsUnique()
.HasFilter("\"IsActual\" = TRUE");
b.ToTable("Posts");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Request", b =>
{
b.Property<string>("Id")
.HasColumnType("text");
b.Property<string>("Email")
.IsRequired()
.HasColumnType("text");
b.Property<bool>("IsCancel")
.HasColumnType("boolean");
b.Property<DateTime>("RequestDate")
.HasColumnType("timestamp without time zone");
b.Property<double>("Sum")
.HasColumnType("double precision");
b.Property<string>("WorkerId")
.IsRequired()
.HasColumnType("text");
b.HasKey("Id");
b.HasIndex("WorkerId");
b.ToTable("Requests");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Salary", b =>
{
b.Property<string>("Id")
.HasColumnType("text");
b.Property<DateTime>("SalaryDate")
.HasColumnType("timestamp without time zone");
b.Property<string>("WorkerId")
.IsRequired()
.HasColumnType("text");
b.Property<double>("WorkerSalary")
.HasColumnType("double precision");
b.HasKey("Id");
b.HasIndex("WorkerId");
b.ToTable("Salaries");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Software", b =>
{
b.Property<string>("Id")
.HasColumnType("text");
b.Property<bool>("IsDeleted")
.HasColumnType("boolean");
b.Property<string>("ManufacturerId")
.IsRequired()
.HasColumnType("text");
b.Property<string>("PrevPrevSoftwareName")
.HasColumnType("text");
b.Property<string>("PrevSoftwareName")
.HasColumnType("text");
b.Property<double>("Price")
.HasColumnType("double precision");
b.Property<string>("SoftwareName")
.IsRequired()
.HasColumnType("text");
b.Property<int>("SoftwareType")
.HasColumnType("integer");
b.HasKey("Id");
b.HasIndex("ManufacturerId");
b.HasIndex("SoftwareName", "IsDeleted")
.IsUnique()
.HasFilter("\"IsDeleted\" = FALSE");
b.ToTable("Softwares");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.SoftwareHistory", b =>
{
b.Property<string>("Id")
.HasColumnType("text");
b.Property<DateTime>("ChangeDate")
.HasColumnType("timestamp without time zone");
b.Property<double>("OldPrice")
.HasColumnType("double precision");
b.Property<string>("SoftwareId")
.IsRequired()
.HasColumnType("text");
b.HasKey("Id");
b.HasIndex("SoftwareId");
b.ToTable("SoftwareHistories");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Worker", b =>
{
b.Property<string>("Id")
.HasColumnType("text");
b.Property<DateTime>("BirthDate")
.HasColumnType("timestamp without time zone");
b.Property<string>("Configuration")
.IsRequired()
.HasColumnType("jsonb");
b.Property<DateTime?>("DateOfDelete")
.HasColumnType("timestamp without time zone");
b.Property<DateTime>("EmploymentDate")
.HasColumnType("timestamp without time zone");
b.Property<string>("FIO")
.IsRequired()
.HasColumnType("text");
b.Property<bool>("IsDeleted")
.HasColumnType("boolean");
b.Property<string>("PostId")
.IsRequired()
.HasColumnType("text");
b.HasKey("Id");
b.ToTable("Workers");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.InstallationRequest", b =>
{
b.HasOne("SmallSoftwareDatabase.Models.Request", "Request")
.WithMany("InstallationRequests")
.HasForeignKey("RequestId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.HasOne("SmallSoftwareDatabase.Models.Software", "Software")
.WithMany("InstallationRequests")
.HasForeignKey("SoftwareId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Request");
b.Navigation("Software");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Request", b =>
{
b.HasOne("SmallSoftwareDatabase.Models.Worker", "Worker")
.WithMany("Requests")
.HasForeignKey("WorkerId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Worker");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Salary", b =>
{
b.HasOne("SmallSoftwareDatabase.Models.Worker", "Worker")
.WithMany("Salaries")
.HasForeignKey("WorkerId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Worker");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Software", b =>
{
b.HasOne("SmallSoftwareDatabase.Models.Manufacturer", "Manufacturer")
.WithMany("Softwares")
.HasForeignKey("ManufacturerId")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.Navigation("Manufacturer");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.SoftwareHistory", b =>
{
b.HasOne("SmallSoftwareDatabase.Models.Software", "Software")
.WithMany("SoftwareHistories")
.HasForeignKey("SoftwareId")
.OnDelete(DeleteBehavior.Cascade)
.IsRequired();
b.Navigation("Software");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Manufacturer", b =>
{
b.Navigation("Softwares");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Request", b =>
{
b.Navigation("InstallationRequests");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Software", b =>
{
b.Navigation("InstallationRequests");
b.Navigation("SoftwareHistories");
});
modelBuilder.Entity("SmallSoftwareDatabase.Models.Worker", b =>
{
b.Navigation("Requests");
b.Navigation("Salaries");
});
#pragma warning restore 612, 618
}
}
}