2022-06-15 01:00:03 -05:00
|
|
|
namespace ConfusedPolarBear.Plugin.IntroSkipper;
|
|
|
|
|
2022-06-24 00:02:08 -05:00
|
|
|
using System;
|
2022-06-15 01:00:03 -05:00
|
|
|
using System.Collections.ObjectModel;
|
|
|
|
using System.IO;
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Update EDL files associated with a list of episodes.
|
|
|
|
/// </summary>
|
|
|
|
public static class EdlManager
|
|
|
|
{
|
|
|
|
private static ILogger? _logger;
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Initialize EDLManager with a logger.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="logger">ILogger.</param>
|
|
|
|
public static void Initialize(ILogger logger)
|
|
|
|
{
|
|
|
|
_logger = logger;
|
|
|
|
}
|
|
|
|
|
2022-06-24 00:02:08 -05:00
|
|
|
/// <summary>
|
|
|
|
/// Logs the configuration that will be used during EDL file creation.
|
|
|
|
/// </summary>
|
|
|
|
public static void LogConfiguration()
|
|
|
|
{
|
|
|
|
if (_logger is null)
|
|
|
|
{
|
|
|
|
throw new InvalidOperationException("Logger must not be null");
|
|
|
|
}
|
|
|
|
|
|
|
|
var config = Plugin.Instance!.Configuration;
|
|
|
|
|
|
|
|
if (config.EdlAction == EdlAction.None)
|
|
|
|
{
|
|
|
|
_logger.LogDebug("EDL action: None - taking no further action");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
_logger.LogDebug("EDL action: {Action}", config.EdlAction);
|
|
|
|
_logger.LogDebug("Regenerate EDL files: {Regenerate}", config.RegenerateEdlFiles);
|
|
|
|
}
|
|
|
|
|
2022-06-15 01:00:03 -05:00
|
|
|
/// <summary>
|
|
|
|
/// If the EDL action is set to a value other than None, update EDL files for the provided episodes.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="episodes">Episodes to update EDL files for.</param>
|
|
|
|
public static void UpdateEDLFiles(ReadOnlyCollection<QueuedEpisode> episodes)
|
|
|
|
{
|
2022-06-24 00:02:08 -05:00
|
|
|
var regenerate = Plugin.Instance!.Configuration.RegenerateEdlFiles;
|
2022-06-15 01:00:03 -05:00
|
|
|
var action = Plugin.Instance!.Configuration.EdlAction;
|
|
|
|
if (action == EdlAction.None)
|
|
|
|
{
|
|
|
|
_logger?.LogDebug("EDL action is set to none, not updating EDL files");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
_logger?.LogDebug("Updating EDL files with action {Action}", action);
|
|
|
|
|
|
|
|
foreach (var episode in episodes)
|
|
|
|
{
|
|
|
|
var id = episode.EpisodeId;
|
2022-06-24 00:02:08 -05:00
|
|
|
|
2024-04-18 18:08:35 +02:00
|
|
|
bool hasIntro = Plugin.Instance!.Intros.TryGetValue(id, out var intro) && intro.Valid;
|
|
|
|
bool hasCredit = Plugin.Instance!.Credits.TryGetValue(id, out var credit) && credit.Valid;
|
|
|
|
|
|
|
|
if (!hasIntro && !hasCredit)
|
2022-06-24 17:02:40 -05:00
|
|
|
{
|
2024-04-18 18:08:35 +02:00
|
|
|
_logger?.LogDebug("Episode {Id} has neither a valid intro nor credit, skipping", id);
|
2022-06-24 17:02:40 -05:00
|
|
|
continue;
|
|
|
|
}
|
2022-06-24 00:02:08 -05:00
|
|
|
|
2022-06-15 01:00:03 -05:00
|
|
|
var edlPath = GetEdlPath(Plugin.Instance!.GetItemPath(id));
|
|
|
|
|
|
|
|
_logger?.LogTrace("Episode {Id} has EDL path {Path}", id, edlPath);
|
|
|
|
|
2022-06-24 00:02:08 -05:00
|
|
|
if (!regenerate && File.Exists(edlPath))
|
2022-06-20 01:39:56 -05:00
|
|
|
{
|
|
|
|
_logger?.LogTrace("Refusing to overwrite existing EDL file {Path}", edlPath);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
2024-04-18 18:08:35 +02:00
|
|
|
var edlContent = string.Empty;
|
|
|
|
|
|
|
|
if (hasIntro)
|
|
|
|
{
|
|
|
|
edlContent += intro?.ToEdl(action);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (hasCredit)
|
|
|
|
{
|
|
|
|
if (edlContent.Length > 0)
|
|
|
|
{
|
|
|
|
edlContent += Environment.NewLine;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (action == EdlAction.Intro)
|
|
|
|
{
|
|
|
|
edlContent += credit?.ToEdl(EdlAction.Credit);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
edlContent += credit?.ToEdl(action);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
File.WriteAllText(edlPath, edlContent);
|
2022-06-15 01:00:03 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// <summary>
|
|
|
|
/// Given the path to an episode, return the path to the associated EDL file.
|
|
|
|
/// </summary>
|
|
|
|
/// <param name="mediaPath">Full path to episode.</param>
|
|
|
|
/// <returns>Full path to EDL file.</returns>
|
|
|
|
public static string GetEdlPath(string mediaPath)
|
|
|
|
{
|
|
|
|
return Path.ChangeExtension(mediaPath, "edl");
|
|
|
|
}
|
|
|
|
}
|