using System; using System.Collections.Generic; using System.IO; using System.Linq; using System.Threading; using System.Threading.Tasks; using MediaBrowser.Common.Configuration; using MediaBrowser.Controller.IO; using MediaBrowser.Model.Globalization; using MediaBrowser.Model.IO; using MediaBrowser.Model.Tasks; using Microsoft.Extensions.Logging; namespace Emby.Server.Implementations.ScheduledTasks.Tasks { /// /// Deletes old cache files. /// public class DeleteCacheFileTask : IScheduledTask, IConfigurableScheduledTask { /// /// Gets or sets the application paths. /// /// The application paths. private readonly IApplicationPaths _applicationPaths; private readonly ILogger _logger; private readonly IFileSystem _fileSystem; private readonly ILocalizationManager _localization; /// /// Initializes a new instance of the class. /// /// Instance of the interface. /// Instance of the interface. /// Instance of the interface. /// Instance of the interface. public DeleteCacheFileTask( IApplicationPaths appPaths, ILogger logger, IFileSystem fileSystem, ILocalizationManager localization) { _applicationPaths = appPaths; _logger = logger; _fileSystem = fileSystem; _localization = localization; } /// public string Name => _localization.GetLocalizedString("TaskCleanCache"); /// public string Description => _localization.GetLocalizedString("TaskCleanCacheDescription"); /// public string Category => _localization.GetLocalizedString("TasksMaintenanceCategory"); /// public string Key => "DeleteCacheFiles"; /// public bool IsHidden => false; /// public bool IsEnabled => true; /// public bool IsLogged => true; /// public IEnumerable GetDefaultTriggers() { return [ // Every so often new TaskTriggerInfo { Type = TaskTriggerInfoType.IntervalTrigger, IntervalTicks = TimeSpan.FromHours(24).Ticks } ]; } /// public Task ExecuteAsync(IProgress progress, CancellationToken cancellationToken) { var minDateModified = DateTime.UtcNow.AddDays(-30); try { DeleteCacheFilesFromDirectory(_applicationPaths.CachePath, minDateModified, progress, cancellationToken); } catch (DirectoryNotFoundException) { // No biggie here. Nothing to delete } progress.Report(90); minDateModified = DateTime.UtcNow.AddDays(-1); try { DeleteCacheFilesFromDirectory(_applicationPaths.TempDirectory, minDateModified, progress, cancellationToken); } catch (DirectoryNotFoundException) { // No biggie here. Nothing to delete } return Task.CompletedTask; } /// /// Deletes the cache files from directory with a last write time less than a given date. /// /// The directory. /// The min date modified. /// The progress. /// The task cancellation token. private void DeleteCacheFilesFromDirectory(string directory, DateTime minDateModified, IProgress progress, CancellationToken cancellationToken) { var filesToDelete = _fileSystem.GetFiles(directory, true) .Where(f => _fileSystem.GetLastWriteTimeUtc(f) < minDateModified) .ToList(); var index = 0; foreach (var file in filesToDelete) { double percent = index; percent /= filesToDelete.Count; progress.Report(100 * percent); cancellationToken.ThrowIfCancellationRequested(); FileSystemHelper.DeleteFile(_fileSystem, file.FullName, _logger); index++; } FileSystemHelper.DeleteEmptyFolders(_fileSystem, directory, _logger); progress.Report(100); } } }