sonarr-repo-only/NzbDrone.Core/Indexers/FetchAndParseRssService.cs

70 lines
2.0 KiB
C#
Raw Normal View History

2013-04-23 06:06:05 +00:00
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using NLog;
using NzbDrone.Core.Parser.Model;
2013-07-12 06:10:34 +00:00
using NzbDrone.Common.TPL;
2013-04-23 06:06:05 +00:00
namespace NzbDrone.Core.Indexers
{
public interface IFetchAndParseRss
{
2013-09-13 23:17:58 +00:00
List<ReleaseInfo> Fetch();
2013-04-23 06:06:05 +00:00
}
public class FetchAndParseRssService : IFetchAndParseRss
{
private readonly IIndexerService _indexerService;
private readonly IFetchFeedFromIndexers _feedFetcher;
private readonly Logger _logger;
public FetchAndParseRssService(IIndexerService indexerService, IFetchFeedFromIndexers feedFetcher, Logger logger)
{
_indexerService = indexerService;
_feedFetcher = feedFetcher;
_logger = logger;
}
2013-09-13 23:17:58 +00:00
public List<ReleaseInfo> Fetch()
2013-04-23 06:06:05 +00:00
{
2013-09-13 23:17:58 +00:00
var result = new List<ReleaseInfo>();
2013-04-23 06:06:05 +00:00
2013-09-22 05:20:26 +00:00
var indexers = _indexerService.GetAvailableProviders().ToList();
2013-04-23 06:06:05 +00:00
if (!indexers.Any())
{
_logger.Warn("No available indexers. check your configuration.");
return result;
}
_logger.Debug("Available indexers {0}", indexers.Count);
var taskList = new List<Task>();
var taskFactory = new TaskFactory(TaskCreationOptions.LongRunning, TaskContinuationOptions.None);
foreach (var indexer in indexers)
{
var indexerLocal = indexer;
var task = taskFactory.StartNew(() =>
{
var indexerFeed = _feedFetcher.FetchRss(indexerLocal);
lock (result)
{
result.AddRange(indexerFeed);
}
2013-07-12 06:10:34 +00:00
}).LogExceptions();
taskList.Add(task);
}
Task.WaitAll(taskList.ToArray());
2013-04-23 06:06:05 +00:00
_logger.Debug("Found {0} reports", result.Count);
return result;
}
}
}