// using System; using BookHive; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Infrastructure; using Microsoft.EntityFrameworkCore.Metadata; using Microsoft.EntityFrameworkCore.Storage.ValueConversion; #nullable disable namespace BookHive.Migrations { [DbContext(typeof(BookHiveDbContext))] partial class BookHiveDbContextModelSnapshot : ModelSnapshot { protected override void BuildModel(ModelBuilder modelBuilder) { #pragma warning disable 612, 618 modelBuilder .HasAnnotation("ProductVersion", "8.0.20") .HasAnnotation("Relational:MaxIdentifierLength", 128); SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder); modelBuilder.Entity("BookHive.Models.Author", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("int"); SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property("Id")); b.Property("Biography") .HasMaxLength(2000) .HasColumnType("nvarchar(2000)"); b.Property("BirthDate") .HasColumnType("date"); b.Property("FirstName") .IsRequired() .HasMaxLength(100) .HasColumnType("nvarchar(100)"); b.Property("LastName") .IsRequired() .HasMaxLength(100) .HasColumnType("nvarchar(100)"); b.Property("Nationality") .IsRequired() .HasMaxLength(60) .HasColumnType("nvarchar(60)"); b.HasKey("Id"); b.ToTable("Authors"); }); modelBuilder.Entity("BookHive.Models.Book", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("int"); SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property("Id")); b.Property("AuthorId") .HasColumnType("int"); b.Property("Genre") .IsRequired() .HasMaxLength(50) .HasColumnType("nvarchar(50)"); b.Property("Isbn") .IsRequired() .HasColumnType("nvarchar(max)"); b.Property("PageCount") .HasColumnType("int"); b.Property("PublishedDate") .HasColumnType("date"); b.Property("Summary") .HasMaxLength(3000) .HasColumnType("nvarchar(3000)"); b.Property("Title") .IsRequired() .HasMaxLength(200) .HasColumnType("nvarchar(200)"); b.HasKey("Id"); b.HasIndex("AuthorId"); b.ToTable("Books"); }); modelBuilder.Entity("BookHive.Models.Loan", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("int"); SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property("Id")); b.Property("BookId") .HasColumnType("int"); b.Property("DueDate") .HasColumnType("date"); b.Property("LoanDate") .HasColumnType("date"); b.Property("MemberId") .HasColumnType("int"); b.Property("ReturnDate") .HasColumnType("date"); b.HasKey("Id"); b.HasIndex("BookId"); b.HasIndex("MemberId"); b.ToTable("Loans"); }); modelBuilder.Entity("BookHive.Models.Member", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("int"); SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property("Id")); b.Property("Email") .IsRequired() .HasColumnType("nvarchar(max)"); b.Property("FirstName") .IsRequired() .HasMaxLength(100) .HasColumnType("nvarchar(100)"); b.Property("IsActive") .HasColumnType("bit"); b.Property("LastName") .IsRequired() .HasMaxLength(100) .HasColumnType("nvarchar(100)"); b.Property("MembershipDate") .HasColumnType("date"); b.HasKey("Id"); b.ToTable("Members"); }); modelBuilder.Entity("BookHive.Models.Review", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("int"); SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property("Id")); b.Property("BookId") .HasColumnType("int"); b.Property("Comment") .HasMaxLength(1000) .HasColumnType("nvarchar(1000)"); b.Property("CreatedAt") .IsRequired() .HasColumnType("datetime2"); b.Property("MemberId") .HasColumnType("int"); b.Property("Rating") .HasColumnType("int"); b.HasKey("Id"); b.HasIndex("MemberId"); b.HasIndex("BookId", "MemberId") .IsUnique(); b.ToTable("Reviews"); }); modelBuilder.Entity("BookHive.Models.Book", b => { b.HasOne("BookHive.Models.Author", "Author") .WithMany("Books") .HasForeignKey("AuthorId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Author"); }); modelBuilder.Entity("BookHive.Models.Loan", b => { b.HasOne("BookHive.Models.Book", "Book") .WithMany("Loans") .HasForeignKey("BookId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("BookHive.Models.Member", "Member") .WithMany("Loans") .HasForeignKey("MemberId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Book"); b.Navigation("Member"); }); modelBuilder.Entity("BookHive.Models.Review", b => { b.HasOne("BookHive.Models.Book", "Book") .WithMany("Reviews") .HasForeignKey("BookId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("BookHive.Models.Member", "Member") .WithMany("Reviews") .HasForeignKey("MemberId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Book"); b.Navigation("Member"); }); modelBuilder.Entity("BookHive.Models.Author", b => { b.Navigation("Books"); }); modelBuilder.Entity("BookHive.Models.Book", b => { b.Navigation("Loans"); b.Navigation("Reviews"); }); modelBuilder.Entity("BookHive.Models.Member", b => { b.Navigation("Loans"); b.Navigation("Reviews"); }); #pragma warning restore 612, 618 } } }