2011-05-20 03:47:07 +00:00
using System ;
using System.IO ;
using NLog ;
using NzbDrone.Core.Model ;
using NzbDrone.Core.Repository ;
namespace NzbDrone.Core.Providers.Indexer
{
2011-05-20 04:59:35 +00:00
public class InventoryProvider
2011-05-20 03:47:07 +00:00
{
private readonly SeriesProvider _seriesProvider ;
private readonly SeasonProvider _seasonProvider ;
private readonly EpisodeProvider _episodeProvider ;
private readonly HistoryProvider _historyProvider ;
private readonly SabProvider _sabProvider ;
private static readonly Logger Logger = LogManager . GetCurrentClassLogger ( ) ;
2011-05-20 04:59:35 +00:00
public InventoryProvider ( SeriesProvider seriesProvider , SeasonProvider seasonProvider , EpisodeProvider episodeProvider , HistoryProvider historyProvider , SabProvider sabProvider )
2011-05-20 03:47:07 +00:00
{
_seriesProvider = seriesProvider ;
_seasonProvider = seasonProvider ;
_episodeProvider = episodeProvider ;
_historyProvider = historyProvider ;
_sabProvider = sabProvider ;
}
2011-05-20 04:59:35 +00:00
internal bool IsNeeded ( EpisodeParseResult parseResult )
2011-05-20 03:47:07 +00:00
{
2011-05-20 04:59:35 +00:00
var series = _seriesProvider . FindSeries ( parseResult . CleanTitle ) ;
if ( series = = null )
{
Logger . Trace ( "{0} is not mapped to any series in DB. skipping" , parseResult . CleanTitle ) ;
return false ;
}
2011-05-20 05:52:05 +00:00
parseResult . Series = series ;
2011-05-20 03:47:07 +00:00
foreach ( var episodeNumber in parseResult . Episodes )
{
//Todo: How to handle full season files? Currently the episode list is completely empty for these releases
//Todo: Should we assume that the release contains all the episodes that belong to this season and add them from the DB?
//Todo: Fix this so it properly handles multi-epsiode releases (Currently as long as the first episode is needed we download it)
//Todo: for small releases this is less of an issue, but for Full Season Releases this could be an issue if we only need the first episode (or first few)
if ( ! series . Monitored )
{
Logger . Debug ( "{0} is present in the DB but not tracked. skipping." , parseResult . CleanTitle ) ;
return false ;
}
if ( ! _seriesProvider . QualityWanted ( series . SeriesId , parseResult . Quality ) )
{
Logger . Debug ( "Post doesn't meet the quality requirements [{0}]. skipping." , parseResult . Quality ) ;
return false ;
}
if ( _seasonProvider . IsIgnored ( series . SeriesId , parseResult . SeasonNumber ) )
{
Logger . Debug ( "Season {0} is currently set to ignore. skipping." , parseResult . SeasonNumber ) ;
return false ;
}
var episodeInfo = _episodeProvider . GetEpisode ( series . SeriesId , parseResult . SeasonNumber , episodeNumber ) ;
if ( episodeInfo = = null )
{
episodeInfo = _episodeProvider . GetEpisode ( series . SeriesId , parseResult . AirDate ) ;
}
//if still null we should add the temp episode
if ( episodeInfo = = null )
{
Logger . Debug ( "Episode {0} doesn't exist in db. adding it now." , parseResult ) ;
episodeInfo = new Episode
{
SeriesId = series . SeriesId ,
AirDate = DateTime . Now . Date ,
EpisodeNumber = episodeNumber ,
SeasonNumber = parseResult . SeasonNumber ,
Title = parseResult . EpisodeTitle ,
Overview = String . Empty ,
Language = "en"
} ;
_episodeProvider . AddEpisode ( episodeInfo ) ;
}
if ( ! _episodeProvider . IsNeeded ( parseResult , episodeInfo ) )
{
Logger . Debug ( "Episode {0} is not needed. skipping." , parseResult ) ;
return false ;
}
2011-05-20 04:59:35 +00:00
2011-05-20 03:47:07 +00:00
if ( _historyProvider . Exists ( episodeInfo . EpisodeId , parseResult . Quality , parseResult . Proper ) )
{
Logger . Debug ( "Episode {0} is in history. skipping." , parseResult ) ;
return false ;
}
//Congragulations younge feed item! you have made it this far. you are truly special!!!
2011-05-20 05:52:05 +00:00
Logger . Debug ( "Episode {0} is needed" , parseResult ) ;
2011-05-20 03:47:07 +00:00
return true ;
}
return false ;
}
}
}