コード例 #1
0
        public ProcessedDecisions ProcessDecisions(List <DownloadDecision> decisions)
        {
            var qualifiedReports     = GetQualifiedReports(decisions);
            var prioritizedDecisions = _prioritizeDownloadDecision.PrioritizeDecisions(qualifiedReports);
            var grabbed = new List <DownloadDecision>();
            var pending = new List <DownloadDecision>();

            foreach (var report in prioritizedDecisions)
            {
                var remoteEpisode = report.RemoteEpisode;

                var episodeIds = remoteEpisode.Episodes.Select(e => e.Id).ToList();

                //Skip if already grabbed
                if (grabbed.SelectMany(r => r.RemoteEpisode.Episodes)
                    .Select(e => e.Id)
                    .ToList()
                    .Intersect(episodeIds)
                    .Any())
                {
                    continue;
                }

                if (report.TemporarilyRejected)
                {
                    _pendingReleaseService.Add(report);
                    pending.Add(report);
                    continue;
                }

                if (pending.SelectMany(r => r.RemoteEpisode.Episodes)
                    .Select(e => e.Id)
                    .ToList()
                    .Intersect(episodeIds)
                    .Any())
                {
                    continue;
                }

                try
                {
                    _downloadService.DownloadReport(remoteEpisode);
                    grabbed.Add(report);
                }
                catch (Exception e)
                {
                    //TODO: support for store & forward
                    //We'll need to differentiate between a download client error and an indexer error
                    _logger.Warn(e, "Couldn't add report to download queue. " + remoteEpisode);
                }
            }

            return(new ProcessedDecisions(grabbed, pending, decisions.Where(d => d.Rejected).ToList()));
        }
コード例 #2
0
        public ProcessedDecisions ProcessDecisions(List <DownloadDecision> decisions)
        {
            var qualifiedReports     = GetQualifiedReports(decisions);
            var prioritizedDecisions = _prioritizeDownloadDecision.PrioritizeDecisions(qualifiedReports);
            var grabbed  = new List <DownloadDecision>();
            var pending  = new List <DownloadDecision>();
            var failed   = new List <DownloadDecision>();
            var rejected = decisions.Where(d => d.Rejected).ToList();

            var usenetFailed  = false;
            var torrentFailed = false;

            foreach (var report in prioritizedDecisions)
            {
                var remoteEpisode    = report.RemoteEpisode;
                var downloadProtocol = report.RemoteEpisode.Release.DownloadProtocol;

                // Skip if already grabbed
                if (IsEpisodeProcessed(grabbed, report))
                {
                    continue;
                }

                if (report.TemporarilyRejected)
                {
                    _pendingReleaseService.Add(report, PendingReleaseReason.Delay);
                    pending.Add(report);
                    continue;
                }

                if (downloadProtocol == DownloadProtocol.Usenet && usenetFailed ||
                    downloadProtocol == DownloadProtocol.Torrent && torrentFailed)
                {
                    failed.Add(report);
                    continue;
                }

                try
                {
                    _downloadService.DownloadReport(remoteEpisode);
                    grabbed.Add(report);
                }
                catch (ReleaseUnavailableException)
                {
                    _logger.Warn("Failed to download release from indexer, no longer available. " + remoteEpisode);
                    rejected.Add(report);
                }
                catch (Exception ex)
                {
                    if (ex is DownloadClientUnavailableException || ex is DownloadClientAuthenticationException)
                    {
                        _logger.Debug(ex, "Failed to send release to download client, storing until later. " + remoteEpisode);
                        failed.Add(report);

                        if (downloadProtocol == DownloadProtocol.Usenet)
                        {
                            usenetFailed = true;
                        }
                        else if (downloadProtocol == DownloadProtocol.Torrent)
                        {
                            torrentFailed = true;
                        }
                    }
                    else
                    {
                        _logger.Warn(ex, "Couldn't add report to download queue. " + remoteEpisode);
                    }
                }
            }

            pending.AddRange(ProcessFailedGrabs(grabbed, failed));

            return(new ProcessedDecisions(grabbed, pending, rejected));
        }
コード例 #3
0
        public ProcessedDecisions ProcessDecisions(List <DownloadDecision> decisions)
        {
            var qualifiedReports     = GetQualifiedReports(decisions);
            var prioritizedDecisions = _prioritizeDownloadDecision.PrioritizeDecisionsForMovies(qualifiedReports);
            var grabbed = new List <DownloadDecision>();
            var pending = new List <DownloadDecision>();

            foreach (var report in prioritizedDecisions)
            {
                var remoteMovie = report.RemoteMovie;

                if (remoteMovie == null || remoteMovie.Movie == null)
                {
                    continue;
                }

                List <int> movieIds = new List <int> {
                    remoteMovie.Movie.Id
                };


                //Skip if already grabbed
                if (grabbed.Select(r => r.RemoteMovie.Movie)
                    .Select(e => e.Id)
                    .ToList()
                    .Intersect(movieIds)
                    .Any())
                {
                    continue;
                }

                if (report.TemporarilyRejected)
                {
                    _pendingReleaseService.Add(report);
                    pending.Add(report);
                    continue;
                }

                if (report.Rejections.Any())
                {
                    _logger.Debug("Rejecting release {0} because {1}", report.ToString(), report.Rejections.First().Reason);
                    continue;
                }



                if (pending.Select(r => r.RemoteMovie.Movie)
                    .Select(e => e.Id)
                    .ToList()
                    .Intersect(movieIds)
                    .Any())
                {
                    continue;
                }

                try
                {
                    _downloadService.DownloadReport(remoteMovie, false);
                    grabbed.Add(report);
                }
                catch (Exception e)
                {
                    //TODO: support for store & forward
                    //We'll need to differentiate between a download client error and an indexer error
                    _logger.Warn(e, "Couldn't add report to download queue. " + remoteMovie);
                }
            }

            return(new ProcessedDecisions(grabbed, pending, decisions.Where(d => d.Rejected).ToList()));
        }