mirror of https://github.com/Radarr/Radarr
57 lines
1.8 KiB
C#
57 lines
1.8 KiB
C#
using System;
|
|
using NLog;
|
|
|
|
namespace NzbDrone.Core.Movies
|
|
{
|
|
public interface ICheckIfMovieShouldBeRefreshed
|
|
{
|
|
bool ShouldRefresh(MovieMetadata movie);
|
|
}
|
|
|
|
public class ShouldRefreshMovie : ICheckIfMovieShouldBeRefreshed
|
|
{
|
|
private readonly Logger _logger;
|
|
|
|
public ShouldRefreshMovie(Logger logger)
|
|
{
|
|
_logger = logger;
|
|
}
|
|
|
|
public bool ShouldRefresh(MovieMetadata movie)
|
|
{
|
|
if (movie == null)
|
|
{
|
|
_logger.Warn("Movie metadata does not exist, should not be refreshed.");
|
|
return false;
|
|
}
|
|
|
|
if (movie.LastInfoSync < DateTime.UtcNow.AddDays(-180))
|
|
{
|
|
_logger.Trace("Movie {0} last updated more than 180 days ago, should refresh.", movie.Title);
|
|
return true;
|
|
}
|
|
|
|
if (movie.LastInfoSync >= DateTime.UtcNow.AddHours(-12))
|
|
{
|
|
_logger.Trace("Movie {0} last updated less than 12 hours ago, should not be refreshed.", movie.Title);
|
|
return false;
|
|
}
|
|
|
|
if (movie.Status == MovieStatusType.Announced || movie.Status == MovieStatusType.InCinemas)
|
|
{
|
|
_logger.Trace("Movie {0} is announced or in cinemas, should refresh.", movie.Title);
|
|
return true;
|
|
}
|
|
|
|
if (movie.Status == MovieStatusType.Released && movie.PhysicalReleaseDate() >= DateTime.UtcNow.AddDays(-30))
|
|
{
|
|
_logger.Trace("Movie {0} is released since less than 30 days, should refresh", movie.Title);
|
|
return true;
|
|
}
|
|
|
|
_logger.Trace("Movie {0} came out long ago, should not be refreshed.", movie.Title);
|
|
return false;
|
|
}
|
|
}
|
|
}
|