6ccf002e51
* Recaps and Previews Support * Add draft UI of preview / recap edit * remove intro/credit tasks * Update configPage.html * rename task * Reorganize settings by relation * More standardized formatting * Some additional formatting * fix a typo * Update configPage.html * Allow missing recap / prview data * More risk to corrupt than benefit * Update TimeStamps.cs * Update PluginConfiguration.cs * Update configPage.html * Update PluginConfiguration.cs * Add chapter regex to settings * Move all UI into UI section * Move ending seconds with similar * Add default * fixes * Update SkipIntroController.cs * Autoskip all segments * Check if adjacent segment * Update AutoSkip.cs * Update AutoSkip.cs * Settings apply to all segment types * Update SegmentProvider * Update configPage.html Whoops * Update Plugin.cs * Update AutoSkip.cs * Let’s call it missing instead * Update BaseItemAnalyzerTask.cs * Update BaseItemAnalyzerTask.cs * Update BaseItemAnalyzerTask.cs * Move "select" all below list * Clarify button wording * Update configPage.html * Nope, long client list will hide it * Simplify wording * Update QueuedEpisode.cs * fix unit test for ffmpeg7 * Add migration * Restore DataContract * update * Update configPage.html * remove analyzed status * Update AutoSkip.cs * Update configPage.html typo * Store analyzed items in seasoninfo * Update VisualizationController.cs * update * Update IntroSkipperDbContext.cs * Add preview / recap delete * This keeps changing itself * Update SkipIntroController.cs * Rather add it to be removed --------- Co-authored-by: rlauu <46294892+rlauu@users.noreply.github.com> Co-authored-by: TwistedUmbrellaX <1173913+AbandonedCart@users.noreply.github.com> Co-authored-by: Kilian von Pflugk <github@jumoog.io>
122 lines
4.0 KiB
C#
122 lines
4.0 KiB
C#
// Copyright (C) 2024 Intro-Skipper contributors <intro-skipper.org>
|
|
// SPDX-License-Identifier: GPL-3.0-only.
|
|
|
|
using System;
|
|
using System.Collections.Generic;
|
|
using System.IO;
|
|
using System.Linq;
|
|
using System.Threading;
|
|
using System.Threading.Tasks;
|
|
using IntroSkipper.Manager;
|
|
using MediaBrowser.Controller.Library;
|
|
using MediaBrowser.Model.Tasks;
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
namespace IntroSkipper.ScheduledTasks;
|
|
|
|
/// <summary>
|
|
/// Analyze all television episodes for introduction sequences.
|
|
/// </summary>
|
|
public class CleanCacheTask : IScheduledTask
|
|
{
|
|
private readonly ILogger<CleanCacheTask> _logger;
|
|
|
|
private readonly ILoggerFactory _loggerFactory;
|
|
|
|
private readonly ILibraryManager _libraryManager;
|
|
|
|
/// <summary>
|
|
/// Initializes a new instance of the <see cref="CleanCacheTask"/> class.
|
|
/// </summary>
|
|
/// <param name="loggerFactory">Logger factory.</param>
|
|
/// <param name="libraryManager">Library manager.</param>
|
|
/// <param name="logger">Logger.</param>
|
|
public CleanCacheTask(
|
|
ILogger<CleanCacheTask> logger,
|
|
ILoggerFactory loggerFactory,
|
|
ILibraryManager libraryManager)
|
|
{
|
|
_logger = logger;
|
|
_loggerFactory = loggerFactory;
|
|
_libraryManager = libraryManager;
|
|
}
|
|
|
|
/// <summary>
|
|
/// Gets the task name.
|
|
/// </summary>
|
|
public string Name => "Clean Intro Skipper Cache";
|
|
|
|
/// <summary>
|
|
/// Gets the task category.
|
|
/// </summary>
|
|
public string Category => "Intro Skipper";
|
|
|
|
/// <summary>
|
|
/// Gets the task description.
|
|
/// </summary>
|
|
public string Description => "Clear Intro Skipper cache of unused files.";
|
|
|
|
/// <summary>
|
|
/// Gets the task key.
|
|
/// </summary>
|
|
public string Key => "CPBIntroSkipperCleanCache";
|
|
|
|
/// <summary>
|
|
/// Cleans the cache of unused files.
|
|
/// Clears the Segment cache by removing files that are no longer associated with episodes in the library.
|
|
/// Clears the IgnoreList cache by removing items that are no longer associated with seasons in the library.
|
|
/// </summary>
|
|
/// <param name="progress">Task progress.</param>
|
|
/// <param name="cancellationToken">Cancellation token.</param>
|
|
/// <returns>Task.</returns>
|
|
public async Task ExecuteAsync(IProgress<double> progress, CancellationToken cancellationToken)
|
|
{
|
|
if (_libraryManager is null)
|
|
{
|
|
throw new InvalidOperationException("Library manager was null");
|
|
}
|
|
|
|
var queueManager = new QueueManager(
|
|
_loggerFactory.CreateLogger<QueueManager>(),
|
|
_libraryManager);
|
|
|
|
// Retrieve media items and get valid episode IDs
|
|
var queue = queueManager.GetMediaItems();
|
|
var validEpisodeIds = queue.Values
|
|
.SelectMany(episodes => episodes.Select(e => e.EpisodeId))
|
|
.ToHashSet();
|
|
|
|
await Plugin.Instance!.CleanTimestamps(validEpisodeIds).ConfigureAwait(false);
|
|
|
|
// Identify invalid episode IDs
|
|
var invalidEpisodeIds = Directory.EnumerateFiles(Plugin.Instance!.FingerprintCachePath)
|
|
.Select(filePath => Path.GetFileNameWithoutExtension(filePath).Split('-')[0])
|
|
.Where(episodeIdStr => Guid.TryParse(episodeIdStr, out var episodeId) && !validEpisodeIds.Contains(episodeId))
|
|
.Select(Guid.Parse)
|
|
.ToHashSet();
|
|
|
|
// Delete cache files for invalid episode IDs
|
|
foreach (var episodeId in invalidEpisodeIds)
|
|
{
|
|
_logger.LogDebug("Deleting cache files for episode ID: {EpisodeId}", episodeId);
|
|
FFmpegWrapper.DeleteEpisodeCache(episodeId);
|
|
}
|
|
|
|
// Clean up Season information by removing items that are no longer exist.
|
|
await Plugin.Instance!.CleanSeasonInfoAsync(queue.Keys).ConfigureAwait(false);
|
|
|
|
Plugin.Instance!.AnalyzeAgain = true;
|
|
|
|
progress.Report(100);
|
|
}
|
|
|
|
/// <summary>
|
|
/// Get task triggers.
|
|
/// </summary>
|
|
/// <returns>Task triggers.</returns>
|
|
public IEnumerable<TaskTriggerInfo> GetDefaultTriggers()
|
|
{
|
|
return [];
|
|
}
|
|
}
|