using System; using System.Collections.Generic; using System.Globalization; using System.Linq; using System.Threading; using System.Threading.Tasks; using MediaBrowser.Common.Configuration; using MediaBrowser.Model.Globalization; using MediaBrowser.Model.IO; using MediaBrowser.Model.Tasks; namespace Emby.Server.Implementations.ScheduledTasks.Tasks { /// /// Deletes old log files. /// public class DeleteLogFileTask : IScheduledTask, IConfigurableScheduledTask { private readonly IConfigurationManager _configurationManager; private readonly IFileSystem _fileSystem; private readonly ILocalizationManager _localization; /// /// Initializes a new instance of the class. /// /// The configuration manager. /// The file system. /// The localization manager. public DeleteLogFileTask(IConfigurationManager configurationManager, IFileSystem fileSystem, ILocalizationManager localization) { _configurationManager = configurationManager; _fileSystem = fileSystem; _localization = localization; } /// public string Name => _localization.GetLocalizedString("TaskCleanLogs"); /// public string Description => string.Format( CultureInfo.InvariantCulture, _localization.GetLocalizedString("TaskCleanLogsDescription"), _configurationManager.CommonConfiguration.LogFileRetentionDays); /// public string Category => _localization.GetLocalizedString("TasksMaintenanceCategory"); /// public string Key => "CleanLogFiles"; /// public bool IsHidden => false; /// public bool IsEnabled => true; /// public bool IsLogged => true; /// /// Creates the triggers that define when the task will run. /// /// IEnumerable{BaseTaskTrigger}. public IEnumerable GetDefaultTriggers() { return new[] { new TaskTriggerInfo { Type = TaskTriggerInfo.TriggerInterval, IntervalTicks = TimeSpan.FromHours(24).Ticks } }; } /// public Task ExecuteAsync(IProgress progress, CancellationToken cancellationToken) { // Delete log files more than n days old var minDateModified = DateTime.UtcNow.AddDays(-_configurationManager.CommonConfiguration.LogFileRetentionDays); // Only delete files that serilog doesn't manage (anything that doesn't start with 'log_' var filesToDelete = _fileSystem.GetFiles(_configurationManager.CommonApplicationPaths.LogDirectoryPath, true) .Where(f => !f.Name.StartsWith("log_", StringComparison.Ordinal) && _fileSystem.GetLastWriteTimeUtc(f) < minDateModified) .ToList(); var index = 0; foreach (var file in filesToDelete) { double percent = index / (double)filesToDelete.Count; progress.Report(100 * percent); cancellationToken.ThrowIfCancellationRequested(); _fileSystem.DeleteFile(file.FullName); index++; } progress.Report(100); return Task.CompletedTask; } } }