// using System; using CarShowroomDatabaseStorage; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Infrastructure; using Microsoft.EntityFrameworkCore.Storage.ValueConversion; using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; #nullable disable namespace CarShowroomDatabaseStorage.Migrations { [DbContext(typeof(CarShowroomDatabase))] partial class CarShowroomDatabaseModelSnapshot : ModelSnapshot { protected override void BuildModel(ModelBuilder modelBuilder) { #pragma warning disable 612, 618 modelBuilder .HasAnnotation("ProductVersion", "7.0.18") .HasAnnotation("Relational:MaxIdentifierLength", 63); NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Car", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasColumnName("car_id"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Color") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(50) .HasColumnType("character varying(50)") .HasDefaultValue("empty_string") .HasColumnName("car_color"); b.Property("ModelId") .HasColumnType("integer") .HasColumnName("car_model_id"); b.Property("ReleaseDate") .HasColumnType("timestamp with time zone") .HasColumnName("car_releasedate"); b.HasKey("Id"); b.HasIndex("ModelId"); b.ToTable("car"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Client", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasColumnName("client_id"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Name") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(50) .HasColumnType("character varying(50)") .HasDefaultValue("empty_string") .HasColumnName("client_name"); b.Property("PhoneNumber") .IsRequired() .HasMaxLength(25) .HasColumnType("character varying(25)") .HasColumnName("client_phonenumber"); b.HasKey("Id"); b.HasIndex("PhoneNumber") .IsUnique(); b.ToTable("client"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Employee", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasColumnName("employee_id"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Email") .IsRequired() .HasMaxLength(40) .HasColumnType("character varying(40)") .HasColumnName("employee_email"); b.Property("Name") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(50) .HasColumnType("character varying(50)") .HasDefaultValue("empty_string") .HasColumnName("employee_name"); b.Property("Password") .IsRequired() .ValueGeneratedOnAdd() .HasMaxLength(32) .HasColumnType("character varying(32)") .HasDefaultValue("empty_string") .HasColumnName("employee_password"); b.HasKey("Id"); b.HasIndex("Email") .IsUnique(); b.ToTable("employee"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Make", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasColumnName("make_id"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Name") .IsRequired() .HasMaxLength(50) .HasColumnType("character varying(50)") .HasColumnName("make_name"); b.HasKey("Id"); b.HasIndex("Name") .IsUnique(); b.ToTable("make"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Model", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasColumnName("model_id"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("MakeId") .HasColumnType("integer") .HasColumnName("model_make_id"); b.Property("Name") .IsRequired() .HasMaxLength(50) .HasColumnType("character varying(50)") .HasColumnName("model_name"); b.Property("Price") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasDefaultValue(-1) .HasColumnName("model_price"); b.HasKey("Id"); b.HasIndex("MakeId"); b.HasIndex("Name") .IsUnique(); b.ToTable("model"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Sale", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasColumnName("sale_id"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("ClientId") .HasColumnType("integer") .HasColumnName("sale_client_id"); b.Property("Cost") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasDefaultValue(-1) .HasColumnName("sale_cost"); b.Property("EmployeeId") .HasColumnType("integer") .HasColumnName("sale_employee_id"); b.Property("SaleTime") .HasColumnType("timestamp with time zone") .HasColumnName("sale_time"); b.HasKey("Id"); b.HasIndex("ClientId"); b.HasIndex("EmployeeId"); b.ToTable("sale"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.SaleCar", b => { b.Property("SaleId") .HasColumnType("integer") .HasColumnName("sale_id"); b.Property("CarId") .HasColumnType("integer") .HasColumnName("car_id"); b.HasKey("SaleId", "CarId"); b.HasIndex("CarId"); b.ToTable("sale_car"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.SaleService", b => { b.Property("SaleId") .HasColumnType("integer") .HasColumnName("sale_id"); b.Property("ServiceId") .HasColumnType("integer") .HasColumnName("service_id"); b.HasKey("SaleId", "ServiceId"); b.HasIndex("ServiceId"); b.ToTable("sale_service"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Service", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasColumnName("service_id"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Cost") .ValueGeneratedOnAdd() .HasColumnType("integer") .HasDefaultValue(-1) .HasColumnName("service_cost"); b.Property("Name") .IsRequired() .HasMaxLength(50) .HasColumnType("character varying(50)") .HasColumnName("service_name"); b.HasKey("Id"); b.HasIndex("Name") .IsUnique(); b.ToTable("service"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Car", b => { b.HasOne("CarShowroomDatabaseStorage.Entities.Model", "Model") .WithMany("Cars") .HasForeignKey("ModelId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.Navigation("Model"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Model", b => { b.HasOne("CarShowroomDatabaseStorage.Entities.Make", "Make") .WithMany("Models") .HasForeignKey("MakeId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.Navigation("Make"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Sale", b => { b.HasOne("CarShowroomDatabaseStorage.Entities.Client", "Client") .WithMany("Sales") .HasForeignKey("ClientId") .OnDelete(DeleteBehavior.SetNull); b.HasOne("CarShowroomDatabaseStorage.Entities.Employee", "Employee") .WithMany("Sales") .HasForeignKey("EmployeeId") .OnDelete(DeleteBehavior.SetNull); b.Navigation("Client"); b.Navigation("Employee"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.SaleCar", b => { b.HasOne("CarShowroomDatabaseStorage.Entities.Car", "Car") .WithMany("SaleCars") .HasForeignKey("CarId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("CarShowroomDatabaseStorage.Entities.Sale", "Sale") .WithMany("SaleCars") .HasForeignKey("SaleId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.Navigation("Car"); b.Navigation("Sale"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.SaleService", b => { b.HasOne("CarShowroomDatabaseStorage.Entities.Sale", "Sale") .WithMany("SaleServices") .HasForeignKey("SaleId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.HasOne("CarShowroomDatabaseStorage.Entities.Service", "Service") .WithMany("SaleServices") .HasForeignKey("ServiceId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Sale"); b.Navigation("Service"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Car", b => { b.Navigation("SaleCars"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Client", b => { b.Navigation("Sales"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Employee", b => { b.Navigation("Sales"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Make", b => { b.Navigation("Models"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Model", b => { b.Navigation("Cars"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Sale", b => { b.Navigation("SaleCars"); b.Navigation("SaleServices"); }); modelBuilder.Entity("CarShowroomDatabaseStorage.Entities.Service", b => { b.Navigation("SaleServices"); }); #pragma warning restore 612, 618 } } }