// using System; using Microsoft.EntityFrameworkCore; using Microsoft.EntityFrameworkCore.Infrastructure; using Microsoft.EntityFrameworkCore.Metadata; using Microsoft.EntityFrameworkCore.Migrations; using Microsoft.EntityFrameworkCore.Storage.ValueConversion; using PlaylistShared.Api.Data; #nullable disable namespace PlaylistShared.Api.Data.Migrations { [DbContext(typeof(ApplicationDbContext))] [Migration("20260414111229_AddUserFavorites")] partial class AddUserFavorites { /// protected override void BuildTargetModel(ModelBuilder modelBuilder) { #pragma warning disable 612, 618 modelBuilder .HasAnnotation("ProductVersion", "10.0.5") .HasAnnotation("Relational:MaxIdentifierLength", 128); SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRole", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("uniqueidentifier"); 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", (string)null); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("int"); SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property("Id")); b.Property("ClaimType") .HasColumnType("nvarchar(max)"); b.Property("ClaimValue") .HasColumnType("nvarchar(max)"); b.Property("RoleId") .HasColumnType("uniqueidentifier"); b.HasKey("Id"); b.HasIndex("RoleId"); b.ToTable("AspNetRoleClaims", (string)null); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("int"); SqlServerPropertyBuilderExtensions.UseIdentityColumn(b.Property("Id")); b.Property("ClaimType") .HasColumnType("nvarchar(max)"); b.Property("ClaimValue") .HasColumnType("nvarchar(max)"); b.Property("UserId") .HasColumnType("uniqueidentifier"); b.HasKey("Id"); b.HasIndex("UserId"); b.ToTable("AspNetUserClaims", (string)null); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b => { b.Property("LoginProvider") .HasColumnType("nvarchar(450)"); b.Property("ProviderKey") .HasColumnType("nvarchar(450)"); b.Property("ProviderDisplayName") .HasColumnType("nvarchar(max)"); b.Property("UserId") .HasColumnType("uniqueidentifier"); b.HasKey("LoginProvider", "ProviderKey"); b.HasIndex("UserId"); b.ToTable("AspNetUserLogins", (string)null); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b => { b.Property("UserId") .HasColumnType("uniqueidentifier"); b.Property("RoleId") .HasColumnType("uniqueidentifier"); b.HasKey("UserId", "RoleId"); b.HasIndex("RoleId"); b.ToTable("AspNetUserRoles", (string)null); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b => { b.Property("UserId") .HasColumnType("uniqueidentifier"); b.Property("LoginProvider") .HasColumnType("nvarchar(450)"); b.Property("Name") .HasColumnType("nvarchar(450)"); b.Property("Value") .HasColumnType("nvarchar(max)"); b.HasKey("UserId", "LoginProvider", "Name"); b.ToTable("AspNetUserTokens", (string)null); }); modelBuilder.Entity("PlaylistShared.Api.Entities.ApplicationUser", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("uniqueidentifier"); 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("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("RefreshToken") .HasColumnType("nvarchar(max)"); b.Property("RefreshTokenExpiryUtc") .HasColumnType("datetime2"); b.Property("SecurityStamp") .HasColumnType("nvarchar(max)"); b.Property("TwoFactorEnabled") .HasColumnType("bit"); b.Property("UserName") .HasMaxLength(256) .HasColumnType("nvarchar(256)"); b.Property("YandexAccessToken") .HasColumnType("nvarchar(max)"); b.Property("YandexId") .HasColumnType("nvarchar(max)"); b.Property("YandexRefreshToken") .HasColumnType("nvarchar(max)"); b.Property("YandexTokenExpiryUtc") .HasColumnType("datetime2"); b.HasKey("Id"); b.HasIndex("NormalizedEmail") .HasDatabaseName("EmailIndex"); b.HasIndex("NormalizedUserName") .IsUnique() .HasDatabaseName("UserNameIndex") .HasFilter("[NormalizedUserName] IS NOT NULL"); b.ToTable("AspNetUsers", (string)null); }); modelBuilder.Entity("PlaylistShared.Api.Entities.FavoritePlaylist", b => { b.Property("UserId") .HasColumnType("uniqueidentifier"); b.Property("SharedPlaylistId") .HasColumnType("uniqueidentifier"); b.Property("AddedAtUtc") .HasColumnType("datetime2"); b.HasKey("UserId", "SharedPlaylistId"); b.HasIndex("SharedPlaylistId"); b.ToTable("FavoritePlaylists"); }); modelBuilder.Entity("PlaylistShared.Api.Entities.SharedPlaylist", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("uniqueidentifier"); b.Property("AddPermission") .HasColumnType("int"); b.Property("CoverUrl") .HasColumnType("nvarchar(max)"); b.Property("CreatedAt") .HasColumnType("datetime2"); b.Property("CreatorUserId") .HasColumnType("uniqueidentifier"); b.Property("Description") .HasColumnType("nvarchar(max)"); b.Property("IsDeleted") .HasColumnType("bit"); b.Property("PlayPermission") .HasColumnType("int"); b.Property("RemovePermission") .HasColumnType("int"); b.Property("ShareToken") .IsRequired() .HasColumnType("nvarchar(450)"); b.Property("Title") .IsRequired() .HasMaxLength(255) .HasColumnType("nvarchar(255)"); b.Property("UpdatedAt") .HasColumnType("datetime2"); b.Property("ViewPermission") .HasColumnType("int"); b.Property("YandexPlaylistKind") .IsRequired() .HasMaxLength(50) .HasColumnType("nvarchar(50)"); b.Property("YandexPlaylistOwnerUid") .IsRequired() .HasMaxLength(50) .HasColumnType("nvarchar(50)"); b.Property("YandexPlaylistUuid") .IsRequired() .HasMaxLength(50) .HasColumnType("nvarchar(50)"); b.HasKey("Id"); b.HasIndex("CreatorUserId"); b.HasIndex("ShareToken") .IsUnique(); b.ToTable("SharedPlaylists"); }); modelBuilder.Entity("PlaylistShared.Api.Entities.TrackAdditionLog", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("uniqueidentifier"); b.Property("AddedAtUtc") .HasColumnType("datetime2"); b.Property("AddedByUserId") .HasColumnType("uniqueidentifier"); b.Property("SessionId") .IsRequired() .HasColumnType("nvarchar(449)"); b.Property("SharedPlaylistId") .HasColumnType("uniqueidentifier"); b.Property("TrackId") .IsRequired() .HasColumnType("nvarchar(450)"); b.HasKey("Id"); b.HasIndex("AddedByUserId"); b.HasIndex("SessionId"); b.HasIndex("SharedPlaylistId", "TrackId"); b.ToTable("TrackAdditionLogs"); }); modelBuilder.Entity("PlaylistShared.Api.Entities.UserSession", b => { b.Property("SessionId") .HasMaxLength(449) .HasColumnType("nvarchar(449)"); b.Property("AssociatedUserId") .HasColumnType("uniqueidentifier"); b.Property("ClientIpAddress") .HasColumnType("nvarchar(max)"); b.Property("FirstSeenUtc") .HasColumnType("datetime2"); b.Property("LastSeenUtc") .HasColumnType("datetime2"); b.Property("UserAgent") .HasColumnType("nvarchar(max)"); b.HasKey("SessionId"); b.HasIndex("AssociatedUserId"); b.ToTable("UserSessions"); }); modelBuilder.Entity("TrackRemovalLog", b => { b.Property("Id") .ValueGeneratedOnAdd() .HasColumnType("uniqueidentifier"); b.Property("RemovedAtUtc") .HasColumnType("datetime2"); b.Property("RemovedByUserId") .HasColumnType("uniqueidentifier"); b.Property("SessionId") .IsRequired() .HasColumnType("nvarchar(449)"); b.Property("SharedPlaylistId") .HasColumnType("uniqueidentifier"); b.Property("TrackId") .IsRequired() .HasColumnType("nvarchar(450)"); b.HasKey("Id"); b.HasIndex("RemovedByUserId"); b.HasIndex("SessionId"); b.HasIndex("SharedPlaylistId", "TrackId"); b.ToTable("TrackRemovalLogs"); }); 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("PlaylistShared.Api.Entities.ApplicationUser", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b => { b.HasOne("PlaylistShared.Api.Entities.ApplicationUser", 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("PlaylistShared.Api.Entities.ApplicationUser", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b => { b.HasOne("PlaylistShared.Api.Entities.ApplicationUser", null) .WithMany() .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); }); modelBuilder.Entity("PlaylistShared.Api.Entities.FavoritePlaylist", b => { b.HasOne("PlaylistShared.Api.Entities.SharedPlaylist", "SharedPlaylist") .WithMany() .HasForeignKey("SharedPlaylistId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.HasOne("PlaylistShared.Api.Entities.ApplicationUser", "User") .WithMany("FavoritePlaylists") .HasForeignKey("UserId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("SharedPlaylist"); b.Navigation("User"); }); modelBuilder.Entity("PlaylistShared.Api.Entities.SharedPlaylist", b => { b.HasOne("PlaylistShared.Api.Entities.ApplicationUser", "Creator") .WithMany("OwnedPlaylists") .HasForeignKey("CreatorUserId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.Navigation("Creator"); }); modelBuilder.Entity("PlaylistShared.Api.Entities.TrackAdditionLog", b => { b.HasOne("PlaylistShared.Api.Entities.ApplicationUser", "AddedByUser") .WithMany() .HasForeignKey("AddedByUserId") .OnDelete(DeleteBehavior.Restrict); b.HasOne("PlaylistShared.Api.Entities.UserSession", "Session") .WithMany("TrackAdditionLogs") .HasForeignKey("SessionId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.HasOne("PlaylistShared.Api.Entities.SharedPlaylist", "SharedPlaylist") .WithMany("TrackAdditionLogs") .HasForeignKey("SharedPlaylistId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("AddedByUser"); b.Navigation("Session"); b.Navigation("SharedPlaylist"); }); modelBuilder.Entity("PlaylistShared.Api.Entities.UserSession", b => { b.HasOne("PlaylistShared.Api.Entities.ApplicationUser", "User") .WithMany() .HasForeignKey("AssociatedUserId") .OnDelete(DeleteBehavior.SetNull); b.Navigation("User"); }); modelBuilder.Entity("TrackRemovalLog", b => { b.HasOne("PlaylistShared.Api.Entities.ApplicationUser", "RemovedByUser") .WithMany() .HasForeignKey("RemovedByUserId") .OnDelete(DeleteBehavior.Restrict); b.HasOne("PlaylistShared.Api.Entities.UserSession", "Session") .WithMany("TrackRemovalLogs") .HasForeignKey("SessionId") .OnDelete(DeleteBehavior.Restrict) .IsRequired(); b.HasOne("PlaylistShared.Api.Entities.SharedPlaylist", "SharedPlaylist") .WithMany() .HasForeignKey("SharedPlaylistId") .OnDelete(DeleteBehavior.Cascade) .IsRequired(); b.Navigation("RemovedByUser"); b.Navigation("Session"); b.Navigation("SharedPlaylist"); }); modelBuilder.Entity("PlaylistShared.Api.Entities.ApplicationUser", b => { b.Navigation("FavoritePlaylists"); b.Navigation("OwnedPlaylists"); }); modelBuilder.Entity("PlaylistShared.Api.Entities.SharedPlaylist", b => { b.Navigation("TrackAdditionLogs"); }); modelBuilder.Entity("PlaylistShared.Api.Entities.UserSession", b => { b.Navigation("TrackAdditionLogs"); b.Navigation("TrackRemovalLogs"); }); #pragma warning restore 612, 618 } } }