using MediaBrowser.Common.Kernel; using MediaBrowser.Model.Tasks; using System; using System.Collections.Generic; using System.ComponentModel.Composition; using System.IO; using System.Linq; using System.Threading; using System.Threading.Tasks; namespace MediaBrowser.Common.ScheduledTasks.Tasks { /// /// Deletes old log files /// [Export(typeof(IScheduledTask))] public class DeleteLogFileTask : BaseScheduledTask { /// /// Creates the triggers that define when the task will run /// /// IEnumerable{BaseTaskTrigger}. protected override IEnumerable GetDefaultTriggers() { var trigger = new DailyTrigger { TimeOfDay = TimeSpan.FromHours(2) }; //2am return new[] { trigger }; } /// /// Returns the task to be executed /// /// The cancellation token. /// The progress. /// Task. protected override Task ExecuteInternal(CancellationToken cancellationToken, IProgress progress) { return Task.Run(() => { // Delete log files more than n days old var minDateModified = DateTime.UtcNow.AddDays(-(Kernel.Configuration.LogFileRetentionDays)); var filesToDelete = new DirectoryInfo(Kernel.ApplicationPaths.LogDirectoryPath).EnumerateFileSystemInfos("*", SearchOption.AllDirectories) .Where(f => f.LastWriteTimeUtc < minDateModified) .ToList(); var index = 0; foreach (var file in filesToDelete) { double percent = index; percent /= filesToDelete.Count; progress.Report(100 * percent); cancellationToken.ThrowIfCancellationRequested(); File.Delete(file.FullName); index++; } progress.Report(100); }); } /// /// Gets the name of the task /// /// The name. public override string Name { get { return "Log file cleanup"; } } /// /// Gets the description. /// /// The description. public override string Description { get { return string.Format("Deletes log files that are more than {0} days old.", Kernel.Configuration.LogFileRetentionDays); } } /// /// Gets the category. /// /// The category. public override string Category { get { return "Maintenance"; } } } }