|
|
@ -26,72 +26,76 @@ namespace NzbDrone.Core.Tv
|
|
|
|
|
|
|
|
|
|
|
|
public void SetEpisodeMonitoredStatus(Series series, MonitoringOptions monitoringOptions)
|
|
|
|
public void SetEpisodeMonitoredStatus(Series series, MonitoringOptions monitoringOptions)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_logger.Debug("[{0}] Setting episode monitored status.", series.Title);
|
|
|
|
if (monitoringOptions != null)
|
|
|
|
|
|
|
|
|
|
|
|
var episodes = _episodeService.GetEpisodeBySeries(series.Id);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (monitoringOptions.IgnoreEpisodesWithFiles)
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_logger.Debug("Ignoring Episodes with Files");
|
|
|
|
_logger.Debug("[{0}] Setting episode monitored status.", series.Title);
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.HasFile), false);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
var episodes = _episodeService.GetEpisodeBySeries(series.Id);
|
|
|
|
{
|
|
|
|
|
|
|
|
_logger.Debug("Monitoring Episodes with Files");
|
|
|
|
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.HasFile), true);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (monitoringOptions.IgnoreEpisodesWithoutFiles)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
_logger.Debug("Ignoring Episodes without Files");
|
|
|
|
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => !e.HasFile && e.AirDateUtc.HasValue && e.AirDateUtc.Value.Before(DateTime.UtcNow)), false);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
if (monitoringOptions.IgnoreEpisodesWithFiles)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
_logger.Debug("Monitoring Episodes without Files");
|
|
|
|
_logger.Debug("Ignoring Episodes with Files");
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => !e.HasFile && e.AirDateUtc.HasValue && e.AirDateUtc.Value.Before(DateTime.UtcNow)), true);
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.HasFile), false);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
var lastSeason = series.Seasons.Select(s => s.SeasonNumber).MaxOrDefault();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var s in series.Seasons)
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
var season = s;
|
|
|
|
_logger.Debug("Monitoring Episodes with Files");
|
|
|
|
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.HasFile), true);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (season.Monitored)
|
|
|
|
if (monitoringOptions.IgnoreEpisodesWithoutFiles)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (!monitoringOptions.IgnoreEpisodesWithFiles && !monitoringOptions.IgnoreEpisodesWithoutFiles)
|
|
|
|
_logger.Debug("Ignoring Episodes without Files");
|
|
|
|
{
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => !e.HasFile && e.AirDateUtc.HasValue && e.AirDateUtc.Value.Before(DateTime.UtcNow)), false);
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.SeasonNumber == season.SeasonNumber), true);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
else
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (!monitoringOptions.IgnoreEpisodesWithFiles && !monitoringOptions.IgnoreEpisodesWithoutFiles)
|
|
|
|
_logger.Debug("Monitoring Episodes without Files");
|
|
|
|
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => !e.HasFile && e.AirDateUtc.HasValue && e.AirDateUtc.Value.Before(DateTime.UtcNow)), true);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
var lastSeason = series.Seasons.Select(s => s.SeasonNumber).MaxOrDefault();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
foreach (var s in series.Seasons)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
var season = s;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (season.Monitored)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.SeasonNumber == season.SeasonNumber), false);
|
|
|
|
if (!monitoringOptions.IgnoreEpisodesWithFiles && !monitoringOptions.IgnoreEpisodesWithoutFiles)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.SeasonNumber == season.SeasonNumber), true);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
else if (season.SeasonNumber == 0)
|
|
|
|
else
|
|
|
|
{
|
|
|
|
{
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.SeasonNumber == season.SeasonNumber), false);
|
|
|
|
if (!monitoringOptions.IgnoreEpisodesWithFiles && !monitoringOptions.IgnoreEpisodesWithoutFiles)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.SeasonNumber == season.SeasonNumber), false);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
else if (season.SeasonNumber == 0)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
ToggleEpisodesMonitoredState(episodes.Where(e => e.SeasonNumber == season.SeasonNumber), false);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (season.SeasonNumber < lastSeason)
|
|
|
|
if (season.SeasonNumber < lastSeason)
|
|
|
|
{
|
|
|
|
|
|
|
|
if (episodes.Where(e => e.SeasonNumber == season.SeasonNumber).All(e => !e.Monitored))
|
|
|
|
|
|
|
|
{
|
|
|
|
{
|
|
|
|
season.Monitored = false;
|
|
|
|
if (episodes.Where(e => e.SeasonNumber == season.SeasonNumber).All(e => !e.Monitored))
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
season.Monitored = false;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
_episodeService.UpdateEpisodes(episodes);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
_seriesService.UpdateSeries(series);
|
|
|
|
_seriesService.UpdateSeries(series);
|
|
|
|
_episodeService.UpdateEpisodes(episodes);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
private void ToggleEpisodesMonitoredState(IEnumerable<Episode> episodes, bool monitored)
|
|
|
|
private void ToggleEpisodesMonitoredState(IEnumerable<Episode> episodes, bool monitored)
|
|
|
|