mirror of https://github.com/Sonarr/Sonarr
50 lines
1.5 KiB
C#
50 lines
1.5 KiB
C#
using System;
|
|
using System.Linq;
|
|
using NLog;
|
|
|
|
namespace NzbDrone.Core.Tv
|
|
{
|
|
public interface ICheckIfSeriesShouldBeRefreshed
|
|
{
|
|
bool ShouldRefresh(Series series);
|
|
}
|
|
|
|
public class ShouldRefreshSeries : ICheckIfSeriesShouldBeRefreshed
|
|
{
|
|
private readonly IEpisodeService _episodeService;
|
|
private readonly Logger _logger;
|
|
|
|
public ShouldRefreshSeries(IEpisodeService episodeService, Logger logger)
|
|
{
|
|
_episodeService = episodeService;
|
|
_logger = logger;
|
|
}
|
|
|
|
public bool ShouldRefresh(Series series)
|
|
{
|
|
if (series.Status == SeriesStatusType.Continuing)
|
|
{
|
|
_logger.Trace("Series {0} is continuing, should refresh.", series.Title);
|
|
return true;
|
|
}
|
|
|
|
if (series.LastInfoSync < DateTime.UtcNow.AddDays(-30))
|
|
{
|
|
_logger.Trace("Series {0} last updated more than 30 days ago, should refresh.", series.Title);
|
|
return true;
|
|
}
|
|
|
|
var lastEpisode = _episodeService.GetEpisodeBySeries(series.Id).OrderByDescending(e => e.AirDateUtc).FirstOrDefault();
|
|
|
|
if (lastEpisode != null && lastEpisode.AirDateUtc > DateTime.UtcNow.AddDays(-30))
|
|
{
|
|
_logger.Trace("Last episode in {0} aired less than 30 days ago, should refresh.", series.Title);
|
|
return true;
|
|
}
|
|
|
|
_logger.Trace("Series {0} should not be refreshed.", series.Title);
|
|
return false;
|
|
}
|
|
}
|
|
}
|