From 2d06095447b972c8c7239277428e2c67c8b7ca86 Mon Sep 17 00:00:00 2001 From: LukePulverenti Date: Mon, 25 Feb 2013 22:43:04 -0500 Subject: plugin security fixes and other abstractions --- .../ScheduledTasks/ImageCleanupTask.cs | 210 --------------------- 1 file changed, 210 deletions(-) delete mode 100644 MediaBrowser.Controller/ScheduledTasks/ImageCleanupTask.cs (limited to 'MediaBrowser.Controller/ScheduledTasks/ImageCleanupTask.cs') diff --git a/MediaBrowser.Controller/ScheduledTasks/ImageCleanupTask.cs b/MediaBrowser.Controller/ScheduledTasks/ImageCleanupTask.cs deleted file mode 100644 index 7e0094a67..000000000 --- a/MediaBrowser.Controller/ScheduledTasks/ImageCleanupTask.cs +++ /dev/null @@ -1,210 +0,0 @@ -using MediaBrowser.Common.ScheduledTasks; -using MediaBrowser.Controller.Entities; -using MediaBrowser.Controller.Entities.Movies; -using MediaBrowser.Model.Logging; -using System; -using System.Collections.Generic; -using System.IO; -using System.Linq; -using System.Threading; -using System.Threading.Tasks; - -namespace MediaBrowser.Controller.ScheduledTasks -{ - /// - /// Class ImageCleanupTask - /// - public class ImageCleanupTask : BaseScheduledTask - { - /// - /// Initializes a new instance of the class. - /// - /// The kernel. - /// The task manager. - /// The logger. - public ImageCleanupTask(Kernel kernel, ITaskManager taskManager, ILogger logger) - : base(kernel, taskManager, logger) - { - } - - /// - /// Creates the triggers that define when the task will run - /// - /// IEnumerable{BaseTaskTrigger}. - public override IEnumerable GetDefaultTriggers() - { - return new ITaskTrigger[] - { - new DailyTrigger { TimeOfDay = TimeSpan.FromHours(2) } - }; - } - - /// - /// Returns the task to be executed - /// - /// The cancellation token. - /// The progress. - /// Task. - protected override async Task ExecuteInternal(CancellationToken cancellationToken, IProgress progress) - { - await EnsureChapterImages(cancellationToken).ConfigureAwait(false); - - // First gather all image files - var files = GetFiles(Kernel.FFMpegManager.AudioImagesDataPath) - .Concat(GetFiles(Kernel.FFMpegManager.VideoImagesDataPath)) - .Concat(GetFiles(Kernel.ProviderManager.ImagesDataPath)) - .ToList(); - - // Now gather all items - var items = Kernel.RootFolder.RecursiveChildren.ToList(); - items.Add(Kernel.RootFolder); - - // Determine all possible image paths - var pathsInUse = items.SelectMany(GetPathsInUse) - .Distinct(StringComparer.OrdinalIgnoreCase) - .ToDictionary(p => p, StringComparer.OrdinalIgnoreCase); - - var numComplete = 0; - - var tasks = files.Select(file => Task.Run(() => - { - cancellationToken.ThrowIfCancellationRequested(); - - if (!pathsInUse.ContainsKey(file)) - { - cancellationToken.ThrowIfCancellationRequested(); - - try - { - File.Delete(file); - } - catch (IOException ex) - { - Logger.ErrorException("Error deleting {0}", ex, file); - } - } - - // Update progress - lock (progress) - { - numComplete++; - double percent = numComplete; - percent /= files.Count; - - progress.Report(100 * percent); - } - })); - - await Task.WhenAll(tasks).ConfigureAwait(false); - } - - /// - /// Ensures the chapter images. - /// - /// The cancellation token. - /// Task. - private Task EnsureChapterImages(CancellationToken cancellationToken) - { - var videos = Kernel.RootFolder.RecursiveChildren.OfType