jellyfin/Emby.Server.Implementations/Channels/ChannelPostScanTask.cs

101 lines
3.3 KiB
C#
Raw Normal View History

using System;
2014-09-22 23:56:54 +02:00
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
2021-12-12 03:31:30 +01:00
using Jellyfin.Data.Enums;
using MediaBrowser.Controller.Channels;
using MediaBrowser.Controller.Entities;
using MediaBrowser.Controller.Library;
using Microsoft.Extensions.Logging;
2014-09-22 23:56:54 +02:00
namespace Emby.Server.Implementations.Channels
2014-09-22 23:56:54 +02:00
{
2020-04-14 21:36:29 +02:00
/// <summary>
2020-04-19 19:39:12 +02:00
/// A task to remove all non-installed channels from the database.
2020-04-14 21:36:29 +02:00
/// </summary>
2015-07-29 05:42:03 +02:00
public class ChannelPostScanTask
2014-09-22 23:56:54 +02:00
{
private readonly IChannelManager _channelManager;
private readonly ILogger _logger;
2015-08-22 19:50:37 +02:00
private readonly ILibraryManager _libraryManager;
2014-09-22 23:56:54 +02:00
2020-04-14 21:36:29 +02:00
/// <summary>
/// Initializes a new instance of the <see cref="ChannelPostScanTask"/> class.
/// </summary>
/// <param name="channelManager">The channel manager.</param>
/// <param name="logger">The logger.</param>
/// <param name="libraryManager">The library manager.</param>
public ChannelPostScanTask(IChannelManager channelManager, ILogger logger, ILibraryManager libraryManager)
2014-09-22 23:56:54 +02:00
{
_channelManager = channelManager;
_logger = logger;
2015-08-22 19:50:37 +02:00
_libraryManager = libraryManager;
2014-09-22 23:56:54 +02:00
}
2020-04-14 21:36:29 +02:00
/// <summary>
/// Runs this task.
/// </summary>
/// <param name="progress">The progress.</param>
/// <param name="cancellationToken">The cancellation token.</param>
/// <returns>The completed task.</returns>
2018-09-12 19:26:21 +02:00
public Task Run(IProgress<double> progress, CancellationToken cancellationToken)
2014-09-22 23:56:54 +02:00
{
2018-09-12 19:26:21 +02:00
CleanDatabase(cancellationToken);
2016-03-20 22:32:26 +01:00
2014-09-22 23:56:54 +02:00
progress.Report(100);
2018-09-12 19:26:21 +02:00
return Task.CompletedTask;
2014-09-22 23:56:54 +02:00
}
2018-09-12 19:26:21 +02:00
private void CleanDatabase(CancellationToken cancellationToken)
2015-08-22 19:50:37 +02:00
{
2015-11-06 16:02:22 +01:00
var installedChannelIds = ((ChannelManager)_channelManager).GetInstalledChannelIds();
2015-08-22 19:50:37 +02:00
2019-02-14 17:02:46 +01:00
var uninstalledChannels = _libraryManager.GetItemList(new InternalItemsQuery
2015-08-22 19:50:37 +02:00
{
2021-12-12 03:31:30 +01:00
IncludeItemTypes = new[] { BaseItemKind.Channel },
ExcludeItemIds = installedChannelIds.ToArray()
2015-08-22 19:50:37 +02:00
});
2019-02-14 17:02:46 +01:00
foreach (var channel in uninstalledChannels)
2015-08-22 19:50:37 +02:00
{
cancellationToken.ThrowIfCancellationRequested();
2019-02-14 17:02:46 +01:00
CleanChannel((Channel)channel, cancellationToken);
2015-08-22 19:50:37 +02:00
}
}
private void CleanChannel(Channel channel, CancellationToken cancellationToken)
2015-08-22 19:50:37 +02:00
{
_logger.LogInformation("Cleaning channel {0} from database", channel.Id);
2015-08-22 19:50:37 +02:00
// Delete all channel items
var items = _libraryManager.GetItemList(new InternalItemsQuery
2015-08-22 19:50:37 +02:00
{
ChannelIds = new[] { channel.Id }
2015-08-22 19:50:37 +02:00
});
foreach (var item in items)
2015-08-22 19:50:37 +02:00
{
cancellationToken.ThrowIfCancellationRequested();
2020-01-31 22:23:46 +01:00
_libraryManager.DeleteItem(
item,
new DeleteOptions
{
DeleteFileLocation = false
},
false);
2016-03-20 22:32:26 +01:00
}
// Finally, delete the channel itself
2020-01-31 22:23:46 +01:00
_libraryManager.DeleteItem(
channel,
new DeleteOptions
{
DeleteFileLocation = false
},
false);
2014-09-22 23:56:54 +02:00
}
}
}