mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-11-03 19:17:24 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			198 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
			
		
		
	
	
			198 lines
		
	
	
		
			8.9 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
#pragma warning disable CS1591
 | 
						|
#pragma warning disable SA1601
 | 
						|
 | 
						|
using 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");
 | 
						|
        }
 | 
						|
    }
 | 
						|
}
 |