// using System; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Infrastructure; using Microsoft.EntityFrameworkCore.Migrations; using Microsoft.EntityFrameworkCore.Storage.ValueConversion; using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; using QuotifyBE.Data; #nullable disable namespace QuotifyBE.Migrations { [DbContext(typeof(ApplicationDbContext))] [Migration("20250717083328_user_roles")] partial class user_roles { /// protected override void BuildTargetModel(ModelBuilder modelBuilder) { #pragma warning disable 612, 618 modelBuilder .HasAnnotation("ProductVersion", "9.0.7") .HasAnnotation("Relational:MaxIdentifierLength", 63); NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder); modelBuilder.Entity("QuotifyBE.Entities.Category", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Name") .HasColumnType("text"); b.HasKey("Id"); b.ToTable("Categories"); }); modelBuilder.Entity("QuotifyBE.Entities.Image", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Url") .HasColumnType("text"); b.HasKey("Id"); b.ToTable("Images"); }); modelBuilder.Entity("QuotifyBE.Entities.Quote", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Author") .IsRequired() .HasColumnType("text"); b.Property("CreatedAt") .HasColumnType("timestamp with time zone"); b.Property("ImageId") .HasColumnType("integer"); b.Property("LastUpdatedAt") .HasColumnType("timestamp with time zone"); b.Property("Text") .IsRequired() .HasColumnType("text"); b.Property("UserId") .HasColumnType("integer"); b.HasKey("Id"); b.HasIndex("ImageId"); b.HasIndex("UserId"); b.ToTable("Quotes"); }); modelBuilder.Entity("QuotifyBE.Entities.QuoteCategory", b => { b.Property("QuoteId") .HasColumnType("integer"); b.Property("CategoryId") .HasColumnType("integer"); b.HasKey("QuoteId", "CategoryId"); b.HasIndex("CategoryId"); b.ToTable("QuoteCategories"); }); modelBuilder.Entity("QuotifyBE.Entities.User", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("integer"); NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); b.Property("Email") .IsRequired() .HasColumnType("text"); b.Property("Name") .IsRequired() .HasColumnType("text"); b.Property("PasswordHash") .IsRequired() .HasColumnType("text"); b.Property("Role") .HasColumnType("integer"); b.HasKey("Id"); b.ToTable("Users"); }); modelBuilder.Entity("QuotifyBE.Entities.Quote", b => { b.HasOne("QuotifyBE.Entities.Image", "Image") .WithMany() .HasForeignKey("ImageId"); b.HasOne("QuotifyBE.Entities.User", "User") .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Image"); b.Navigation("User"); }); modelBuilder.Entity("QuotifyBE.Entities.QuoteCategory", b => { b.HasOne("QuotifyBE.Entities.Category", "Category") .WithMany() .HasForeignKey("CategoryId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("QuotifyBE.Entities.Quote", "Quote") .WithMany("QuoteCategories") .HasForeignKey("QuoteId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Category"); b.Navigation("Quote"); }); modelBuilder.Entity("QuotifyBE.Entities.Quote", b => { b.Navigation("QuoteCategories"); }); #pragma warning restore 612, 618 } } }