2023-03-10 19:16:57 +01:00
|
|
|
using System;
|
|
|
|
|
using System.Linq;
|
2023-05-15 14:45:33 +02:00
|
|
|
using System.Threading;
|
2023-03-10 19:16:57 +01:00
|
|
|
|
|
|
|
|
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>
|
2025-04-28 03:18:08 +03:00
|
|
|
[JellyfinMigration("2025-04-20T15:00:00", nameof(FixPlaylistOwner), "615DFA9E-2497-4DBB-A472-61938B752C5B")]
|
|
|
|
|
#pragma warning disable CS0618 // Type or member is obsolete
|
2023-03-10 19:16:57 +01:00
|
|
|
internal class FixPlaylistOwner : IMigrationRoutine
|
2025-04-28 03:18:08 +03:00
|
|
|
#pragma warning restore CS0618 // Type or member is obsolete
|
2023-03-10 19:16:57 +01:00
|
|
|
{
|
2024-11-19 15:43:18 -05:00
|
|
|
private readonly ILogger<FixPlaylistOwner> _logger;
|
2023-03-10 19:16:57 +01:00
|
|
|
private readonly ILibraryManager _libraryManager;
|
|
|
|
|
private readonly IPlaylistManager _playlistManager;
|
|
|
|
|
|
|
|
|
|
public FixPlaylistOwner(
|
2024-11-19 15:43:18 -05:00
|
|
|
ILogger<FixPlaylistOwner> logger,
|
2023-03-10 19:16:57 +01:00
|
|
|
ILibraryManager libraryManager,
|
|
|
|
|
IPlaylistManager playlistManager)
|
|
|
|
|
{
|
|
|
|
|
_logger = logger;
|
|
|
|
|
_libraryManager = libraryManager;
|
|
|
|
|
_playlistManager = playlistManager;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
/// <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;
|
2024-03-26 15:29:48 +01:00
|
|
|
if (shares.Count > 0)
|
2023-03-10 19:16:57 +01:00
|
|
|
{
|
2023-05-12 15:11:59 +02:00
|
|
|
var firstEditShare = shares.First(x => x.CanEdit);
|
2024-04-01 20:43:05 +02:00
|
|
|
if (firstEditShare is not null)
|
2023-05-12 15:11:59 +02:00
|
|
|
{
|
2024-04-01 20:43:05 +02:00
|
|
|
playlist.OwnerUserId = firstEditShare.UserId;
|
2023-05-12 15:11:59 +02:00
|
|
|
playlist.Shares = shares.Where(x => x != firstEditShare).ToArray();
|
2023-05-15 14:45:33 +02:00
|
|
|
playlist.UpdateToRepositoryAsync(ItemUpdateType.MetadataEdit, CancellationToken.None).GetAwaiter().GetResult();
|
|
|
|
|
_playlistManager.SavePlaylistFile(playlist);
|
2023-05-12 15:11:59 +02:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
playlist.OpenAccess = true;
|
2023-05-15 14:45:33 +02:00
|
|
|
playlist.UpdateToRepositoryAsync(ItemUpdateType.MetadataEdit, CancellationToken.None).GetAwaiter().GetResult();
|
2023-03-10 19:16:57 +01:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|