|
|
|
@ -15,6 +15,7 @@ using MediaBrowser.Controller.Entities;
|
|
|
|
|
using MediaBrowser.Controller.Library;
|
|
|
|
|
using MediaBrowser.Controller.MediaEncoding;
|
|
|
|
|
using MediaBrowser.Controller.Providers;
|
|
|
|
|
using MediaBrowser.Model.Configuration;
|
|
|
|
|
using MediaBrowser.Model.Dto;
|
|
|
|
|
using MediaBrowser.Model.Entities;
|
|
|
|
|
using MediaBrowser.Model.IO;
|
|
|
|
@ -62,23 +63,16 @@ namespace Emby.Server.Implementations.MediaEncoder
|
|
|
|
|
/// Determines whether [is eligible for chapter image extraction] [the specified video].
|
|
|
|
|
/// </summary>
|
|
|
|
|
/// <param name="video">The video.</param>
|
|
|
|
|
/// <param name="libraryOptions"></param>
|
|
|
|
|
/// <returns><c>true</c> if [is eligible for chapter image extraction] [the specified video]; otherwise, <c>false</c>.</returns>
|
|
|
|
|
private bool IsEligibleForChapterImageExtraction(Video video)
|
|
|
|
|
private bool IsEligibleForChapterImageExtraction(Video video, LibraryOptions libraryOptions)
|
|
|
|
|
{
|
|
|
|
|
if (video.IsPlaceHolder)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
var libraryOptions = _libraryManager.GetLibraryOptions(video);
|
|
|
|
|
if (libraryOptions is not null)
|
|
|
|
|
{
|
|
|
|
|
if (!libraryOptions.EnableChapterImageExtraction)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
if (libraryOptions is null || !libraryOptions.EnableChapterImageExtraction)
|
|
|
|
|
{
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
@ -99,7 +93,9 @@ namespace Emby.Server.Implementations.MediaEncoder
|
|
|
|
|
|
|
|
|
|
public async Task<bool> RefreshChapterImages(Video video, IDirectoryService directoryService, IReadOnlyList<ChapterInfo> chapters, bool extractImages, bool saveChapters, CancellationToken cancellationToken)
|
|
|
|
|
{
|
|
|
|
|
if (!IsEligibleForChapterImageExtraction(video))
|
|
|
|
|
var libraryOptions = _libraryManager.GetLibraryOptions(video);
|
|
|
|
|
|
|
|
|
|
if (!IsEligibleForChapterImageExtraction(video, libraryOptions))
|
|
|
|
|
{
|
|
|
|
|
extractImages = false;
|
|
|
|
|
}
|
|
|
|
@ -179,6 +175,12 @@ namespace Emby.Server.Implementations.MediaEncoder
|
|
|
|
|
chapter.ImageDateModified = _fileSystem.GetLastWriteTimeUtc(path);
|
|
|
|
|
changesMade = true;
|
|
|
|
|
}
|
|
|
|
|
else if (libraryOptions?.EnableChapterImageExtraction != true)
|
|
|
|
|
{
|
|
|
|
|
// We have an image for the current chapter but the user has disabled chapter image extraction -> delete this chapter's image
|
|
|
|
|
chapter.ImagePath = null;
|
|
|
|
|
changesMade = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (saveChapters && changesMade)
|
|
|
|
|