From 30d6e2cd6ce0702faaec73b7ffb59d9844fb6967 Mon Sep 17 00:00:00 2001 From: Luke Pulverenti Date: Mon, 15 Apr 2013 11:10:12 -0400 Subject: made library scan a bit more conservative --- .../ScheduledTasks/AudioImagesTask.cs | 178 +++++++++++++++++++++ 1 file changed, 178 insertions(+) create mode 100644 MediaBrowser.Server.Implementations/ScheduledTasks/AudioImagesTask.cs (limited to 'MediaBrowser.Server.Implementations/ScheduledTasks/AudioImagesTask.cs') diff --git a/MediaBrowser.Server.Implementations/ScheduledTasks/AudioImagesTask.cs b/MediaBrowser.Server.Implementations/ScheduledTasks/AudioImagesTask.cs new file mode 100644 index 000000000..db809a47b --- /dev/null +++ b/MediaBrowser.Server.Implementations/ScheduledTasks/AudioImagesTask.cs @@ -0,0 +1,178 @@ +using MediaBrowser.Common.IO; +using MediaBrowser.Common.MediaInfo; +using MediaBrowser.Common.ScheduledTasks; +using MediaBrowser.Controller; +using MediaBrowser.Controller.Entities.Audio; +using MediaBrowser.Controller.Library; +using MediaBrowser.Model.Entities; +using System; +using System.Collections.Concurrent; +using System.Collections.Generic; +using System.Linq; +using System.Threading; +using System.Threading.Tasks; + +namespace MediaBrowser.Server.Implementations.ScheduledTasks +{ + /// + /// Class AudioImagesTask + /// + public class AudioImagesTask : IScheduledTask + { + /// + /// Gets or sets the image cache. + /// + /// The image cache. + public FileSystemRepository ImageCache { get; set; } + + /// + /// The _library manager + /// + private readonly ILibraryManager _libraryManager; + /// + /// The _media encoder + /// + private readonly IMediaEncoder _mediaEncoder; + + /// + /// The _locks + /// + private readonly ConcurrentDictionary _locks = new ConcurrentDictionary(); + + /// + /// Initializes a new instance of the class. + /// + /// The library manager. + /// The media encoder. + public AudioImagesTask(ILibraryManager libraryManager, IMediaEncoder mediaEncoder) + { + _libraryManager = libraryManager; + _mediaEncoder = mediaEncoder; + + ImageCache = new FileSystemRepository(Kernel.Instance.FFMpegManager.AudioImagesDataPath); + } + + /// + /// Gets the name of the task + /// + /// The name. + public string Name + { + get { return "Audio image extraction"; } + } + + /// + /// Gets the description. + /// + /// The description. + public string Description + { + get { return "Extracts images from audio files that do not have external images."; } + } + + /// + /// Gets the category. + /// + /// The category. + public string Category + { + get { return "Library"; } + } + + /// + /// Executes the task + /// + /// The cancellation token. + /// The progress. + /// Task. + public async Task Execute(CancellationToken cancellationToken, IProgress progress) + { + var items = _libraryManager.RootFolder.RecursiveChildren + .OfType