mirror of
				https://github.com/jellyfin/jellyfin.git
				synced 2025-10-31 02:27:18 -04: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");
 | |
|         }
 | |
|     }
 | |
| }
 |