| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197 | #pragma warning disable CS1591#pragma warning disable SA1601using System;using Microsoft.EntityFrameworkCore.Migrations;namespace Jellyfin.Server.Implementations.Migrations{    public partial class AddUsers : Migration    {        protected override void Up(MigrationBuilder migrationBuilder)        {            migrationBuilder.CreateTable(                name: "Users",                schema: "jellyfin",                columns: table => new                {                    Id = table.Column<Guid>(nullable: false),                    Username = table.Column<string>(maxLength: 255, nullable: false),                    Password = table.Column<string>(maxLength: 65535, nullable: true),                    EasyPassword = table.Column<string>(maxLength: 65535, nullable: true),                    MustUpdatePassword = table.Column<bool>(nullable: false),                    AudioLanguagePreference = table.Column<string>(maxLength: 255, nullable: true),                    AuthenticationProviderId = table.Column<string>(maxLength: 255, nullable: false),                    PasswordResetProviderId = table.Column<string>(maxLength: 255, nullable: false),                    InvalidLoginAttemptCount = table.Column<int>(nullable: false),                    LastActivityDate = table.Column<DateTime>(nullable: true),                    LastLoginDate = table.Column<DateTime>(nullable: true),                    LoginAttemptsBeforeLockout = table.Column<int>(nullable: true),                    SubtitleMode = table.Column<int>(nullable: false),                    PlayDefaultAudioTrack = table.Column<bool>(nullable: false),                    SubtitleLanguagePreference = table.Column<string>(maxLength: 255, nullable: true),                    DisplayMissingEpisodes = table.Column<bool>(nullable: false),                    DisplayCollectionsView = table.Column<bool>(nullable: false),                    EnableLocalPassword = table.Column<bool>(nullable: false),                    HidePlayedInLatest = table.Column<bool>(nullable: false),                    RememberAudioSelections = table.Column<bool>(nullable: false),                    RememberSubtitleSelections = table.Column<bool>(nullable: false),                    EnableNextEpisodeAutoPlay = table.Column<bool>(nullable: false),                    EnableAutoLogin = table.Column<bool>(nullable: false),                    EnableUserPreferenceAccess = table.Column<bool>(nullable: false),                    MaxParentalAgeRating = table.Column<int>(nullable: true),                    RemoteClientBitrateLimit = table.Column<int>(nullable: true),                    InternalId = table.Column<long>(nullable: false),                    SyncPlayAccess = table.Column<int>(nullable: false),                    RowVersion = table.Column<uint>(nullable: false)                },                constraints: table =>                {                    table.PrimaryKey("PK_Users", x => x.Id);                });            migrationBuilder.CreateTable(                name: "AccessSchedules",                schema: "jellyfin",                columns: table => new                {                    Id = table.Column<int>(nullable: false)                        .Annotation("Sqlite:Autoincrement", true),                    UserId = table.Column<Guid>(nullable: false),                    DayOfWeek = table.Column<int>(nullable: false),                    StartHour = table.Column<double>(nullable: false),                    EndHour = table.Column<double>(nullable: false)                },                constraints: table =>                {                    table.PrimaryKey("PK_AccessSchedules", x => x.Id);                    table.ForeignKey(                        name: "FK_AccessSchedules_Users_UserId",                        column: x => x.UserId,                        principalSchema: "jellyfin",                        principalTable: "Users",                        principalColumn: "Id",                        onDelete: ReferentialAction.Cascade);                });            migrationBuilder.CreateTable(                name: "ImageInfos",                schema: "jellyfin",                columns: table => new                {                    Id = table.Column<int>(nullable: false)                        .Annotation("Sqlite:Autoincrement", true),                    UserId = table.Column<Guid>(nullable: true),                    Path = table.Column<string>(maxLength: 512, nullable: false),                    LastModified = table.Column<DateTime>(nullable: false)                },                constraints: table =>                {                    table.PrimaryKey("PK_ImageInfos", x => x.Id);                    table.ForeignKey(                        name: "FK_ImageInfos_Users_UserId",                        column: x => x.UserId,                        principalSchema: "jellyfin",                        principalTable: "Users",                        principalColumn: "Id",                        onDelete: ReferentialAction.Restrict);                });            migrationBuilder.CreateTable(                name: "Permissions",                schema: "jellyfin",                columns: table => new                {                    Id = table.Column<int>(nullable: false)                        .Annotation("Sqlite:Autoincrement", true),                    Kind = table.Column<int>(nullable: false),                    Value = table.Column<bool>(nullable: false),                    RowVersion = table.Column<uint>(nullable: false),                    Permission_Permissions_Guid = table.Column<Guid>(nullable: true)                },                constraints: table =>                {                    table.PrimaryKey("PK_Permissions", x => x.Id);                    table.ForeignKey(                        name: "FK_Permissions_Users_Permission_Permissions_Guid",                        column: x => x.Permission_Permissions_Guid,                        principalSchema: "jellyfin",                        principalTable: "Users",                        principalColumn: "Id",                        onDelete: ReferentialAction.Restrict);                });            migrationBuilder.CreateTable(                name: "Preferences",                schema: "jellyfin",                columns: table => new                {                    Id = table.Column<int>(nullable: false)                        .Annotation("Sqlite:Autoincrement", true),                    Kind = table.Column<int>(nullable: false),                    Value = table.Column<string>(maxLength: 65535, nullable: false),                    RowVersion = table.Column<uint>(nullable: false),                    Preference_Preferences_Guid = table.Column<Guid>(nullable: true)                },                constraints: table =>                {                    table.PrimaryKey("PK_Preferences", x => x.Id);                    table.ForeignKey(                        name: "FK_Preferences_Users_Preference_Preferences_Guid",                        column: x => x.Preference_Preferences_Guid,                        principalSchema: "jellyfin",                        principalTable: "Users",                        principalColumn: "Id",                        onDelete: ReferentialAction.Restrict);                });            migrationBuilder.CreateIndex(                name: "IX_AccessSchedules_UserId",                schema: "jellyfin",                table: "AccessSchedules",                column: "UserId");            migrationBuilder.CreateIndex(                name: "IX_ImageInfos_UserId",                schema: "jellyfin",                table: "ImageInfos",                column: "UserId",                unique: true);            migrationBuilder.CreateIndex(                name: "IX_Permissions_Permission_Permissions_Guid",                schema: "jellyfin",                table: "Permissions",                column: "Permission_Permissions_Guid");            migrationBuilder.CreateIndex(                name: "IX_Preferences_Preference_Preferences_Guid",                schema: "jellyfin",                table: "Preferences",                column: "Preference_Preferences_Guid");        }        protected override void Down(MigrationBuilder migrationBuilder)        {            migrationBuilder.DropTable(                name: "AccessSchedules",                schema: "jellyfin");            migrationBuilder.DropTable(                name: "ImageInfos",                schema: "jellyfin");            migrationBuilder.DropTable(                name: "Permissions",                schema: "jellyfin");            migrationBuilder.DropTable(                name: "Preferences",                schema: "jellyfin");            migrationBuilder.DropTable(                name: "Users",                schema: "jellyfin");        }    }}
 |