aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorShadowghost <Ghost_of_Stone@web.de>2023-03-10 19:16:57 +0100
committerShadowghost <Ghost_of_Stone@web.de>2023-03-10 19:16:57 +0100
commit8d158df67856bbb9de696f5caa0ec475b172ced2 (patch)
tree0fc3fbe554fe672ffbf93623311dc585429bb5f3
parent76ae599bd3ccfd9808f50dbf5d935aa430783e60 (diff)
Add migration to properly set playlist owner
-rw-r--r--Emby.Server.Implementations/Playlists/PlaylistManager.cs14
-rw-r--r--Jellyfin.Server/Migrations/MigrationRunner.cs3
-rw-r--r--Jellyfin.Server/Migrations/Routines/FixPlaylistOwner.cs67
-rw-r--r--MediaBrowser.Controller/Playlists/IPlaylistManager.cs7
4 files changed, 90 insertions, 1 deletions
diff --git a/Emby.Server.Implementations/Playlists/PlaylistManager.cs b/Emby.Server.Implementations/Playlists/PlaylistManager.cs
index 8cba652e7..c15c2c400 100644
--- a/Emby.Server.Implementations/Playlists/PlaylistManager.cs
+++ b/Emby.Server.Implementations/Playlists/PlaylistManager.cs
@@ -563,5 +563,19 @@ namespace Emby.Server.Implementations.Playlists
}
}
}
+
+ public async Task UpdatePlaylist(Playlist playlist)
+ {
+ var currentPlaylist = (Playlist)_libraryManager.GetItemById(playlist.Id);
+ currentPlaylist.OwnerUserId = playlist.OwnerUserId;
+ currentPlaylist.Shares = playlist.Shares;
+
+ await playlist.UpdateToRepositoryAsync(ItemUpdateType.MetadataEdit, CancellationToken.None).ConfigureAwait(false);
+
+ if (playlist.IsFile)
+ {
+ SavePlaylistFile(currentPlaylist);
+ }
+ }
}
}
diff --git a/Jellyfin.Server/Migrations/MigrationRunner.cs b/Jellyfin.Server/Migrations/MigrationRunner.cs
index d4bf81f10..866262d22 100644
--- a/Jellyfin.Server/Migrations/MigrationRunner.cs
+++ b/Jellyfin.Server/Migrations/MigrationRunner.cs
@@ -40,7 +40,8 @@ namespace Jellyfin.Server.Migrations
typeof(Routines.ReaddDefaultPluginRepository),
typeof(Routines.MigrateDisplayPreferencesDb),
typeof(Routines.RemoveDownloadImagesInAdvance),
- typeof(Routines.MigrateAuthenticationDb)
+ typeof(Routines.MigrateAuthenticationDb),
+ typeof(Routines.FixPlaylistOwner)
};
/// <summary>
diff --git a/Jellyfin.Server/Migrations/Routines/FixPlaylistOwner.cs b/Jellyfin.Server/Migrations/Routines/FixPlaylistOwner.cs
new file mode 100644
index 000000000..d5736fd3c
--- /dev/null
+++ b/Jellyfin.Server/Migrations/Routines/FixPlaylistOwner.cs
@@ -0,0 +1,67 @@
+using System;
+using System.Linq;
+
+using Jellyfin.Data.Enums;
+using MediaBrowser.Controller.Entities;
+using MediaBrowser.Controller.Library;
+using MediaBrowser.Controller.Playlists;
+using Microsoft.Extensions.Logging;
+
+namespace Jellyfin.Server.Migrations.Routines;
+
+/// <summary>
+/// Properly set playlist owner.
+/// </summary>
+internal class FixPlaylistOwner : IMigrationRoutine
+{
+ private readonly ILogger<RemoveDuplicateExtras> _logger;
+ private readonly ILibraryManager _libraryManager;
+ private readonly IPlaylistManager _playlistManager;
+
+ public FixPlaylistOwner(
+ ILogger<RemoveDuplicateExtras> logger,
+ ILibraryManager libraryManager,
+ IPlaylistManager playlistManager)
+ {
+ _logger = logger;
+ _libraryManager = libraryManager;
+ _playlistManager = playlistManager;
+ }
+
+ /// <inheritdoc/>
+ public Guid Id => Guid.Parse("{615DFA9E-2497-4DBB-A472-61938B752C5B}");
+
+ /// <inheritdoc/>
+ public string Name => "FixPlaylistOwner";
+
+ /// <inheritdoc/>
+ public bool PerformOnNewInstall => false;
+
+ /// <inheritdoc/>
+ public void Perform()
+ {
+ var playlists = _libraryManager.GetItemList(new InternalItemsQuery
+ {
+ IncludeItemTypes = new[] { BaseItemKind.Playlist }
+ })
+ .Cast<Playlist>()
+ .Where(x => x.OwnerUserId.Equals(Guid.Empty))
+ .ToArray();
+
+ if (playlists.Length > 0)
+ {
+ foreach (var playlist in playlists)
+ {
+ var shares = playlist.Shares;
+ var firstEditShare = shares.First(x => x.CanEdit);
+ if (firstEditShare is not null && Guid.TryParse(firstEditShare.UserId, out var guid))
+ {
+ playlist.OwnerUserId = guid;
+ playlist.Shares = shares.Where(x => x != firstEditShare).ToArray();
+
+ _playlistManager.UpdatePlaylist(playlist).GetAwaiter().GetResult();
+ }
+ }
+ }
+ }
+}
diff --git a/MediaBrowser.Controller/Playlists/IPlaylistManager.cs b/MediaBrowser.Controller/Playlists/IPlaylistManager.cs
index 201dadb3d..22f974420 100644
--- a/MediaBrowser.Controller/Playlists/IPlaylistManager.cs
+++ b/MediaBrowser.Controller/Playlists/IPlaylistManager.cs
@@ -64,5 +64,12 @@ namespace MediaBrowser.Controller.Playlists
/// <param name="userId">The user id.</param>
/// <returns>Task.</returns>
Task RemovePlaylists(Guid userId);
+
+ /// <summary>
+ /// Updates a playlist.
+ /// </summary>
+ /// <param name="playlist">The updated playlist.</param>
+ /// <returns>Task.</returns>
+ Task UpdatePlaylist(Playlist playlist);
}
}