using System; using System.Collections.Generic; using System.Linq; using System.Threading; using System.Threading.Tasks; using MediaBrowser.Controller.Configuration; using MediaBrowser.Model.Activity; using MediaBrowser.Model.Globalization; using MediaBrowser.Model.Tasks; namespace Emby.Server.Implementations.ScheduledTasks.Tasks { /// /// Deletes old activity log entries. /// public class CleanActivityLogTask : IScheduledTask, IConfigurableScheduledTask { private readonly ILocalizationManager _localization; private readonly IActivityManager _activityManager; private readonly IServerConfigurationManager _serverConfigurationManager; /// /// Initializes a new instance of the class. /// /// Instance of the interface. /// Instance of the interface. /// Instance of the interface. public CleanActivityLogTask( ILocalizationManager localization, IActivityManager activityManager, IServerConfigurationManager serverConfigurationManager) { _localization = localization; _activityManager = activityManager; _serverConfigurationManager = serverConfigurationManager; } /// public string Name => _localization.GetLocalizedString("TaskCleanActivityLog"); /// public string Key => "CleanActivityLog"; /// public string Description => _localization.GetLocalizedString("TaskCleanActivityLogDescription"); /// public string Category => _localization.GetLocalizedString("TasksMaintenanceCategory"); /// public bool IsHidden => false; /// public bool IsEnabled => true; /// public bool IsLogged => true; /// public Task ExecuteAsync(IProgress progress, CancellationToken cancellationToken) { var retentionDays = _serverConfigurationManager.Configuration.ActivityLogRetentionDays; if (!retentionDays.HasValue || retentionDays < 0) { throw new InvalidOperationException($"Activity Log Retention days must be at least 0. Currently: {retentionDays}"); } var startDate = DateTime.UtcNow.AddDays(-retentionDays.Value); return _activityManager.CleanAsync(startDate); } /// public IEnumerable GetDefaultTriggers() { return Enumerable.Empty(); } } }