using System; using System.Collections.Generic; using System.Linq; using System.Text; using NLog; using NzbDrone.Core.Repository; using NzbDrone.Core.Repository.Quality; using SubSonic.Repository; namespace NzbDrone.Core.Providers { public class HistoryProvider : IHistoryProvider { private readonly IRepository _sonicRepo; private static readonly Logger Logger = LogManager.GetCurrentClassLogger(); public HistoryProvider(IRepository sonicRepo) { _sonicRepo = sonicRepo; } #region IHistoryProvider Members public List AllItems() { return _sonicRepo.All().ToList(); } public void Purge() { var all = _sonicRepo.All(); _sonicRepo.DeleteMany(all); Logger.Info("History has been Purged"); } public void Trim() { var old = _sonicRepo.All().Where(h => h.Date < DateTime.Now.AddDays(-30)); _sonicRepo.DeleteMany(old); Logger.Info("History has been trimmed, items older than 30 days have been removed"); } public void Insert(History item) { _sonicRepo.Add(item); Logger.Info("Item added to history: {0} - {1}x{2:00}", item.Episode.Series.Title, item.Episode.SeasonNumber, item.Episode.EpisodeNumber); } public bool Exists(int episodeId, QualityTypes quality, bool proper) { //Looks for the existance of this episode in History if (_sonicRepo.Exists(h => h.EpisodeId == episodeId && (QualityTypes)h.Quality == quality && h.IsProper == proper)) return true; Logger.Debug("Episode not in History: {0}", episodeId); return false; } #endregion } }