From aec59de6b6b2f0707cf556678fb2791d8b3a3f2b Mon Sep 17 00:00:00 2001 From: Mark McDowall Date: Tue, 17 Apr 2012 17:19:03 -0700 Subject: [PATCH] Exceptions when checking SAB's queue are now caught. --- .../Providers/DownloadClients/SabProvider.cs | 39 ++++++++++++------- 1 file changed, 24 insertions(+), 15 deletions(-) diff --git a/NzbDrone.Core/Providers/DownloadClients/SabProvider.cs b/NzbDrone.Core/Providers/DownloadClients/SabProvider.cs index 82c6bdbd4..3682a2ed6 100644 --- a/NzbDrone.Core/Providers/DownloadClients/SabProvider.cs +++ b/NzbDrone.Core/Providers/DownloadClients/SabProvider.cs @@ -46,26 +46,35 @@ private static string GetNzbName(string urlString) public virtual bool IsInQueue(EpisodeParseResult newParseResult) { - var queue = GetQueue().Where(c => c.ParseResult != null); - - var matchigTitle = queue.Where(q => String.Equals(q.ParseResult.CleanTitle, newParseResult.Series.CleanTitle, StringComparison.InvariantCultureIgnoreCase)); - - var matchingTitleWithQuality = matchigTitle.Where(q => q.ParseResult.Quality >= newParseResult.Quality); - - - if (newParseResult.Series.IsDaily) + try { - return matchingTitleWithQuality.Any(q => q.ParseResult.AirDate.Value.Date == newParseResult.AirDate.Value.Date); + var queue = GetQueue().Where(c => c.ParseResult != null); + + var matchigTitle = queue.Where(q => String.Equals(q.ParseResult.CleanTitle, newParseResult.Series.CleanTitle, StringComparison.InvariantCultureIgnoreCase)); + + var matchingTitleWithQuality = matchigTitle.Where(q => q.ParseResult.Quality >= newParseResult.Quality); + + + if (newParseResult.Series.IsDaily) + { + return matchingTitleWithQuality.Any(q => q.ParseResult.AirDate.Value.Date == newParseResult.AirDate.Value.Date); + } + + var matchingSeason = matchingTitleWithQuality.Where(q => q.ParseResult.SeasonNumber == newParseResult.SeasonNumber); + + if (newParseResult.FullSeason) + { + return matchingSeason.Any(); + } + + return matchingSeason.Any(q => q.ParseResult.EpisodeNumbers != null && q.ParseResult.EpisodeNumbers.Any(e => newParseResult.EpisodeNumbers.Contains(e))); } - var matchingSeason = matchingTitleWithQuality.Where(q => q.ParseResult.SeasonNumber == newParseResult.SeasonNumber); - - if (newParseResult.FullSeason) + catch (Exception ex) { - return matchingSeason.Any(); + logger.WarnException("Unable to connect to SABnzbd to check queue.", ex); + return false; } - - return matchingSeason.Any(q => q.ParseResult.EpisodeNumbers != null && q.ParseResult.EpisodeNumbers.Any(e => newParseResult.EpisodeNumbers.Contains(e))); } public virtual bool DownloadNzb(string url, string title)