MigrateUserDb.cs 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. #pragma warning disable CS1591
  2. using System;
  3. using System.Collections.Generic;
  4. using System.IO;
  5. using Emby.Server.Implementations.Data;
  6. using Emby.Server.Implementations.Serialization;
  7. using Jellyfin.Data.Entities;
  8. using Jellyfin.Data.Enums;
  9. using Jellyfin.Server.Implementations;
  10. using MediaBrowser.Controller;
  11. using MediaBrowser.Model.Configuration;
  12. using MediaBrowser.Model.Users;
  13. using Microsoft.Extensions.Logging;
  14. using Newtonsoft.Json;
  15. using SQLitePCL.pretty;
  16. namespace Jellyfin.Server.Migrations.Routines
  17. {
  18. public class MigrateUserDb : IMigrationRoutine
  19. {
  20. private readonly ILogger<MigrateUserDb> _logger;
  21. private readonly IServerApplicationPaths _paths;
  22. private readonly JellyfinDbProvider _provider;
  23. private readonly MyXmlSerializer _xmlSerializer;
  24. public MigrateUserDb(ILogger<MigrateUserDb> logger, IServerApplicationPaths paths, JellyfinDbProvider provider, MyXmlSerializer xmlSerializer)
  25. {
  26. _logger = logger;
  27. _paths = paths;
  28. _provider = provider;
  29. _xmlSerializer = xmlSerializer;
  30. }
  31. public Guid Id => Guid.Parse("5C4B82A2-F053-4009-BD05-B6FCAD82F14C");
  32. public string Name => "MigrateUserDb";
  33. public void Perform()
  34. {
  35. var dataPath = _paths.DataPath;
  36. _logger.LogInformation("Migrating the user database may take a while, do not stop Jellyfin.");
  37. using (var connection = SQLite3.Open(Path.Combine(dataPath, "users.db"), ConnectionFlags.ReadOnly, null))
  38. {
  39. using var dbContext = _provider.CreateContext();
  40. var queryResult = connection.Query("SELECT * FROM LocalUsersv2");
  41. dbContext.RemoveRange(dbContext.Users);
  42. dbContext.SaveChanges();
  43. foreach (var entry in queryResult)
  44. {
  45. var json = JsonConvert.DeserializeObject<Dictionary<string, string>>(entry[2].ToString());
  46. var userDataDir = Path.Combine(_paths.UserConfigurationDirectoryPath, json["Name"]);
  47. var config = (UserConfiguration)_xmlSerializer.DeserializeFromFile(typeof(UserConfiguration), Path.Combine(userDataDir, "config.xml"));
  48. var policy = (UserPolicy)_xmlSerializer.DeserializeFromFile(typeof(UserPolicy), Path.Combine(userDataDir, "policy.xml"));
  49. var user = new User(
  50. json["Name"],
  51. false,
  52. policy.AuthenticatioIsnProviderId,
  53. policy.InvalidLoginAttemptCount,
  54. config.SubtitleMode,
  55. config.PlayDefaultAudioTrack)
  56. {
  57. Id = entry[1].ReadGuidFromBlob(),
  58. InternalId = entry[0].ToInt64(),
  59. MaxParentalAgeRating = policy.MaxParentalRating,
  60. EnableUserPreferenceAccess = policy.EnableUserPreferenceAccess,
  61. RemoteClientBitrateLimit = policy.RemoteClientBitrateLimit,
  62. AuthenticationProviderId = policy.AuthenticatioIsnProviderId,
  63. PasswordResetProviderId = policy.PasswordResetProviderId,
  64. InvalidLoginAttemptCount = policy.InvalidLoginAttemptCount,
  65. LoginAttemptsBeforeLockout = policy.LoginAttemptsBeforeLockout == -1 ? null : new int?(policy.LoginAttemptsBeforeLockout),
  66. SubtitleMode = config.SubtitleMode,
  67. HidePlayedInLatest = config.HidePlayedInLatest,
  68. EnableLocalPassword = config.EnableLocalPassword,
  69. PlayDefaultAudioTrack = config.PlayDefaultAudioTrack,
  70. DisplayCollectionsView = config.DisplayCollectionsView,
  71. DisplayMissingEpisodes = config.DisplayMissingEpisodes,
  72. AudioLanguagePreference = config.AudioLanguagePreference,
  73. RememberAudioSelections = config.RememberAudioSelections,
  74. EnableNextEpisodeAutoPlay = config.EnableNextEpisodeAutoPlay,
  75. RememberSubtitleSelections = config.RememberSubtitleSelections,
  76. SubtitleLanguagePreference = config.SubtitleLanguagePreference,
  77. };
  78. user.SetPermission(PermissionKind.IsAdministrator, policy.IsAdministrator);
  79. user.SetPermission(PermissionKind.IsHidden, policy.IsHidden);
  80. user.SetPermission(PermissionKind.IsDisabled, policy.IsDisabled);
  81. user.SetPermission(PermissionKind.EnableSharedDeviceControl, policy.EnableSharedDeviceControl);
  82. user.SetPermission(PermissionKind.EnableRemoteAccess, policy.EnableRemoteAccess);
  83. user.SetPermission(PermissionKind.EnableLiveTvManagement, policy.EnableLiveTvManagement);
  84. user.SetPermission(PermissionKind.EnableLiveTvAccess, policy.EnableLiveTvAccess);
  85. user.SetPermission(PermissionKind.EnableMediaPlayback, policy.EnableMediaPlayback);
  86. user.SetPermission(PermissionKind.EnableAudioPlaybackTranscoding, policy.EnableAudioPlaybackTranscoding);
  87. user.SetPermission(PermissionKind.EnableVideoPlaybackTranscoding, policy.EnableVideoPlaybackTranscoding);
  88. user.SetPermission(PermissionKind.EnableContentDeletion, policy.EnableContentDeletion);
  89. user.SetPermission(PermissionKind.EnableContentDownloading, policy.EnableContentDownloading);
  90. user.SetPermission(PermissionKind.EnableSyncTranscoding, policy.EnableSyncTranscoding);
  91. user.SetPermission(PermissionKind.EnableMediaConversion, policy.EnableMediaConversion);
  92. user.SetPermission(PermissionKind.EnableAllChannels, policy.EnableAllChannels);
  93. user.SetPermission(PermissionKind.EnableAllDevices, policy.EnableAllDevices);
  94. user.SetPermission(PermissionKind.EnableAllFolders, policy.EnableAllFolders);
  95. user.SetPermission(PermissionKind.EnableRemoteControlOfOtherUsers, policy.EnableRemoteControlOfOtherUsers);
  96. user.SetPermission(PermissionKind.EnablePlaybackRemuxing, policy.EnablePlaybackRemuxing);
  97. user.SetPermission(PermissionKind.ForceRemoteSourceTranscoding, policy.ForceRemoteSourceTranscoding);
  98. user.SetPermission(PermissionKind.EnablePublicSharing, policy.EnablePublicSharing);
  99. foreach (var policyAccessSchedule in policy.AccessSchedules)
  100. {
  101. user.AccessSchedules.Add(policyAccessSchedule);
  102. }
  103. user.SetPreference(PreferenceKind.BlockedTags, policy.BlockedTags);
  104. user.SetPreference(PreferenceKind.EnabledChannels, policy.EnabledChannels);
  105. user.SetPreference(PreferenceKind.EnabledDevices, policy.EnabledDevices);
  106. user.SetPreference(PreferenceKind.EnabledFolders, policy.EnabledFolders);
  107. user.SetPreference(PreferenceKind.EnableContentDeletionFromFolders, policy.EnableContentDeletionFromFolders);
  108. user.SetPreference(PreferenceKind.OrderedViews, config.OrderedViews);
  109. user.SetPreference(PreferenceKind.GroupedFolders, config.GroupedFolders);
  110. user.SetPreference(PreferenceKind.MyMediaExcludes, config.MyMediaExcludes);
  111. user.SetPreference(PreferenceKind.LatestItemExcludes, config.LatestItemsExcludes);
  112. }
  113. dbContext.SaveChanges();
  114. }
  115. try
  116. {
  117. File.Move(Path.Combine(dataPath, "users.db"), Path.Combine(dataPath, "users.db" + ".old"));
  118. }
  119. catch (IOException e)
  120. {
  121. _logger.LogError(e, "Error renaming legacy user database to 'users.db.old'");
  122. }
  123. }
  124. }
  125. }