// using System; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Infrastructure; using Microsoft.EntityFrameworkCore.Metadata; using Microsoft.EntityFrameworkCore.Storage.ValueConversion; using StudyLib.API.Data; namespace StudyLib.Migrations { [DbContext(typeof(StudyLibContext))] partial class StudyLibContextModelSnapshot : ModelSnapshot { protected override void BuildModel(ModelBuilder modelBuilder) { #pragma warning disable 612, 618 modelBuilder .UseIdentityColumns() .HasAnnotation("Relational:MaxIdentifierLength", 128) .HasAnnotation("ProductVersion", "5.0.0"); modelBuilder.Entity("GroupUser", b => { b.Property("GroupsID") .HasColumnType("bigint"); b.Property("UsersId") .HasColumnType("nvarchar(450)"); b.HasKey("GroupsID", "UsersId"); b.HasIndex("UsersId"); b.ToTable("GroupUser"); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRole", b => { b.Property("Id") .HasColumnType("nvarchar(450)"); b.Property("ConcurrencyStamp") .IsConcurrencyToken() .HasColumnType("nvarchar(max)"); b.Property("Name") .HasMaxLength(256) .HasColumnType("nvarchar(256)"); b.Property("NormalizedName") .HasMaxLength(256) .HasColumnType("nvarchar(256)"); b.HasKey("Id"); b.HasIndex("NormalizedName") .IsUnique() .HasDatabaseName("RoleNameIndex") .HasFilter("[NormalizedName] IS NOT NULL"); b.ToTable("AspNetRoles"); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("int") .UseIdentityColumn(); b.Property("ClaimType") .HasColumnType("nvarchar(max)"); b.Property("ClaimValue") .HasColumnType("nvarchar(max)"); b.Property("RoleId") .IsRequired() .HasColumnType("nvarchar(450)"); b.HasKey("Id"); b.HasIndex("RoleId"); b.ToTable("AspNetRoleClaims"); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("int") .UseIdentityColumn(); b.Property("ClaimType") .HasColumnType("nvarchar(max)"); b.Property("ClaimValue") .HasColumnType("nvarchar(max)"); b.Property("UserId") .IsRequired() .HasColumnType("nvarchar(450)"); b.HasKey("Id"); b.HasIndex("UserId"); b.ToTable("AspNetUserClaims"); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b => { b.Property("LoginProvider") .HasMaxLength(128) .HasColumnType("nvarchar(128)"); b.Property("ProviderKey") .HasMaxLength(128) .HasColumnType("nvarchar(128)"); b.Property("ProviderDisplayName") .HasColumnType("nvarchar(max)"); b.Property("UserId") .IsRequired() .HasColumnType("nvarchar(450)"); b.HasKey("LoginProvider", "ProviderKey"); b.HasIndex("UserId"); b.ToTable("AspNetUserLogins"); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b => { b.Property("UserId") .HasColumnType("nvarchar(450)"); b.Property("RoleId") .HasColumnType("nvarchar(450)"); b.HasKey("UserId", "RoleId"); b.HasIndex("RoleId"); b.ToTable("AspNetUserRoles"); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b => { b.Property("UserId") .HasColumnType("nvarchar(450)"); b.Property("LoginProvider") .HasMaxLength(128) .HasColumnType("nvarchar(128)"); b.Property("Name") .HasMaxLength(128) .HasColumnType("nvarchar(128)"); b.Property("Value") .HasColumnType("nvarchar(max)"); b.HasKey("UserId", "LoginProvider", "Name"); b.ToTable("AspNetUserTokens"); }); modelBuilder.Entity("StudyLib.API.Models.Comment", b => { b.Property("ID") .ValueGeneratedOnAdd() .HasColumnType("bigint") .UseIdentityColumn(); b.Property("SubjectId") .HasColumnType("bigint"); b.Property("Text") .IsRequired() .HasColumnType("nvarchar(max)"); b.HasKey("ID"); b.HasIndex("SubjectId"); b.ToTable("Comments"); }); modelBuilder.Entity("StudyLib.API.Models.Group", b => { b.Property("ID") .ValueGeneratedOnAdd() .HasColumnType("bigint") .UseIdentityColumn(); b.Property("AdminId") .HasColumnType("nvarchar(max)"); b.Property("Name") .HasColumnType("nvarchar(max)"); b.Property("Year") .HasColumnType("int"); b.HasKey("ID"); b.ToTable("Groups"); }); modelBuilder.Entity("StudyLib.API.Models.GroupCandidate", b => { b.Property("ID") .ValueGeneratedOnAdd() .HasColumnType("bigint") .UseIdentityColumn(); b.Property("GroupId") .HasColumnType("bigint"); b.Property("UserId") .HasColumnType("nvarchar(450)"); b.HasKey("ID"); b.HasIndex("GroupId"); b.HasIndex("UserId"); b.ToTable("GroupCandidates"); }); modelBuilder.Entity("StudyLib.API.Models.SubjectDeleteRequest", b => { b.Property("ID") .ValueGeneratedOnAdd() .HasColumnType("bigint") .UseIdentityColumn(); b.Property("SubjectId") .HasColumnType("bigint"); b.HasKey("ID"); b.HasIndex("SubjectId"); b.ToTable("SubjectDeleteRequests"); }); modelBuilder.Entity("StudyLib.API.Models.User", b => { b.Property("Id") .HasColumnType("nvarchar(450)"); b.Property("AccessFailedCount") .HasColumnType("int"); b.Property("ConcurrencyStamp") .IsConcurrencyToken() .HasColumnType("nvarchar(max)"); b.Property("Email") .HasMaxLength(256) .HasColumnType("nvarchar(256)"); b.Property("EmailConfirmed") .HasColumnType("bit"); b.Property("FullName") .HasColumnType("nvarchar(max)"); b.Property("LockoutEnabled") .HasColumnType("bit"); b.Property("LockoutEnd") .HasColumnType("datetimeoffset"); b.Property("NormalizedEmail") .HasMaxLength(256) .HasColumnType("nvarchar(256)"); b.Property("NormalizedUserName") .HasMaxLength(256) .HasColumnType("nvarchar(256)"); b.Property("PasswordHash") .HasColumnType("nvarchar(max)"); b.Property("PhoneNumber") .HasColumnType("nvarchar(max)"); b.Property("PhoneNumberConfirmed") .HasColumnType("bit"); b.Property("SecurityStamp") .HasColumnType("nvarchar(max)"); b.Property("TwoFactorEnabled") .HasColumnType("bit"); b.Property("UserName") .HasMaxLength(256) .HasColumnType("nvarchar(256)"); b.HasKey("Id"); b.HasIndex("NormalizedEmail") .HasDatabaseName("EmailIndex"); b.HasIndex("NormalizedUserName") .IsUnique() .HasDatabaseName("UserNameIndex") .HasFilter("[NormalizedUserName] IS NOT NULL"); b.ToTable("AspNetUsers"); }); modelBuilder.Entity("StudyLib.Models.Assignment", b => { b.Property("ID") .ValueGeneratedOnAdd() .HasColumnType("bigint") .UseIdentityColumn(); b.Property("Deadline") .HasColumnType("datetime2"); b.Property("Description") .IsRequired() .HasColumnType("nvarchar(max)"); b.Property("FinalMarkPercent") .HasColumnType("float"); b.Property("Name") .IsRequired() .HasColumnType("nvarchar(max)"); b.Property("SubjectId") .HasColumnType("bigint"); b.HasKey("ID"); b.HasIndex("SubjectId"); b.ToTable("Assignments"); }); modelBuilder.Entity("StudyLib.Models.Subject", b => { b.Property("ID") .ValueGeneratedOnAdd() .HasColumnType("bigint") .UseIdentityColumn(); b.Property("EditedBy") .HasColumnType("nvarchar(max)"); b.Property("ExamDate") .HasColumnType("datetime2"); b.Property("GroupId") .HasColumnType("bigint"); b.Property("LabTeacher") .HasColumnType("nvarchar(max)"); b.Property("LectureTeacher") .HasColumnType("nvarchar(max)"); b.Property("MainExam") .HasColumnType("bit"); b.Property("Name") .IsRequired() .HasColumnType("nvarchar(max)"); b.HasKey("ID"); b.HasIndex("GroupId"); b.ToTable("Subjects"); }); modelBuilder.Entity("StudyLib.Models.Test", b => { b.Property("ID") .ValueGeneratedOnAdd() .HasColumnType("bigint") .UseIdentityColumn(); b.Property("Date") .HasColumnType("datetime2"); b.Property("FinalMarkPercent") .HasColumnType("float"); b.Property("Scope") .IsRequired() .HasColumnType("nvarchar(max)"); b.Property("SubjectId") .HasColumnType("bigint"); b.HasKey("ID"); b.HasIndex("SubjectId"); b.ToTable("Tests"); }); modelBuilder.Entity("GroupUser", b => { b.HasOne("StudyLib.API.Models.Group", null) .WithMany() .HasForeignKey("GroupsID") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("StudyLib.API.Models.User", null) .WithMany() .HasForeignKey("UsersId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b => { b.HasOne("Microsoft.AspNetCore.Identity.IdentityRole", null) .WithMany() .HasForeignKey("RoleId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b => { b.HasOne("StudyLib.API.Models.User", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b => { b.HasOne("StudyLib.API.Models.User", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b => { b.HasOne("Microsoft.AspNetCore.Identity.IdentityRole", null) .WithMany() .HasForeignKey("RoleId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("StudyLib.API.Models.User", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b => { b.HasOne("StudyLib.API.Models.User", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("StudyLib.API.Models.Comment", b => { b.HasOne("StudyLib.Models.Subject", "Subject") .WithMany("Comments") .HasForeignKey("SubjectId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Subject"); }); modelBuilder.Entity("StudyLib.API.Models.GroupCandidate", b => { b.HasOne("StudyLib.API.Models.Group", "Group") .WithMany("GroupCandidates") .HasForeignKey("GroupId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("StudyLib.API.Models.User", "User") .WithMany("GroupCandidates") .HasForeignKey("UserId"); b.Navigation("Group"); b.Navigation("User"); }); modelBuilder.Entity("StudyLib.API.Models.SubjectDeleteRequest", b => { b.HasOne("StudyLib.Models.Subject", "Subject") .WithMany() .HasForeignKey("SubjectId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Subject"); }); modelBuilder.Entity("StudyLib.Models.Assignment", b => { b.HasOne("StudyLib.Models.Subject", "Subject") .WithMany("Assignments") .HasForeignKey("SubjectId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Subject"); }); modelBuilder.Entity("StudyLib.Models.Subject", b => { b.HasOne("StudyLib.API.Models.Group", "Group") .WithMany("Subjects") .HasForeignKey("GroupId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Group"); }); modelBuilder.Entity("StudyLib.Models.Test", b => { b.HasOne("StudyLib.Models.Subject", "Subject") .WithMany("Tests") .HasForeignKey("SubjectId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("Subject"); }); modelBuilder.Entity("StudyLib.API.Models.Group", b => { b.Navigation("GroupCandidates"); b.Navigation("Subjects"); }); modelBuilder.Entity("StudyLib.API.Models.User", b => { b.Navigation("GroupCandidates"); }); modelBuilder.Entity("StudyLib.Models.Subject", b => { b.Navigation("Assignments"); b.Navigation("Comments"); b.Navigation("Tests"); }); #pragma warning restore 612, 618 } } }