// using System; using LibraryAPI.Models; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Infrastructure; using Microsoft.EntityFrameworkCore.Migrations; using Microsoft.EntityFrameworkCore.Storage.ValueConversion; using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; #nullable disable namespace LibraryAPI.Migrations { [DbContext(typeof(LibraryContext))] [Migration("20221106041635_AddGroup")] partial class AddGroup { protected override void BuildTargetModel(ModelBuilder modelBuilder) { #pragma warning disable 612, 618 modelBuilder .HasAnnotation("ProductVersion", "6.0.9") .HasAnnotation("Relational:MaxIdentifierLength", 63); NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder); modelBuilder.Entity("GroupUserAccount", b => { b.Property("GroupsId") .HasColumnType("bigint"); b.Property("UsersId") .HasColumnType("bigint"); b.HasKey("GroupsId", "UsersId"); b.HasIndex("UsersId"); b.ToTable("GroupUserAccount"); }); modelBuilder.Entity("LibraryAPI.Models.Author", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("bigint"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Country") .IsRequired() .HasColumnType("text"); b.Property("Name") .IsRequired() .HasMaxLength(64) .HasColumnType("character varying(64)"); b.Property("YearOfBirth") .HasColumnType("integer"); b.Property("languages") .IsRequired() .HasColumnType("text[]"); b.HasKey("Id"); b.ToTable("Authors"); }); modelBuilder.Entity("LibraryAPI.Models.Book", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("bigint"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("AuthorId") .HasColumnType("bigint"); b.Property("Edition") .HasColumnType("integer"); b.Property("Genres") .IsRequired() .HasColumnType("text[]"); b.Property("ISBN") .IsRequired() .HasColumnType("text"); b.Property("PublicationYear") .HasColumnType("integer"); b.Property("Title") .IsRequired() .HasMaxLength(128) .HasColumnType("character varying(128)"); b.HasKey("Id"); b.HasIndex("AuthorId"); b.ToTable("Books"); }); modelBuilder.Entity("LibraryAPI.Models.Group", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("bigint"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Name") .IsRequired() .HasColumnType("text"); b.HasKey("Id"); b.ToTable("Groups"); }); modelBuilder.Entity("LibraryAPI.Models.UserAccount", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("bigint"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Email") .IsRequired() .HasColumnType("text"); b.Property("Password") .IsRequired() .HasColumnType("text"); b.HasKey("Id"); b.ToTable("Users"); }); modelBuilder.Entity("GroupUserAccount", b => { b.HasOne("LibraryAPI.Models.Group", null) .WithMany() .HasForeignKey("GroupsId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("LibraryAPI.Models.UserAccount", null) .WithMany() .HasForeignKey("UsersId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("LibraryAPI.Models.Book", b => { b.HasOne("LibraryAPI.Models.Author", "Author") .WithMany("Books") .HasForeignKey("AuthorId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Author"); }); modelBuilder.Entity("LibraryAPI.Models.Author", b => { b.Navigation("Books"); }); #pragma warning restore 612, 618 } } }