mirror of
https://github.com/lidarr/lidarr.git
synced 2025-08-21 05:53:33 -07:00
fixed nzbclub parser.
This commit is contained in:
parent
16425cdab6
commit
385edbf464
14 changed files with 94 additions and 64 deletions
|
@ -5,13 +5,11 @@ using NLog;
|
|||
using NzbDrone.Common.Messaging;
|
||||
using NzbDrone.Core.Lifecycle;
|
||||
|
||||
|
||||
namespace NzbDrone.Core.Indexers
|
||||
{
|
||||
|
||||
public class Indexer
|
||||
{
|
||||
public int DefinitionId { get; set; }
|
||||
public int Id { get; set; }
|
||||
public string Name { get; set; }
|
||||
public bool Enable { get; set; }
|
||||
public IIndexerSetting Settings { get; set; }
|
||||
|
@ -30,16 +28,15 @@ namespace NzbDrone.Core.Indexers
|
|||
private readonly IIndexerRepository _indexerRepository;
|
||||
private readonly Logger _logger;
|
||||
|
||||
private readonly IList<IIndexer> _indexers;
|
||||
private readonly List<Func<IIndexer>> _indexers;
|
||||
|
||||
public IndexerService(IIndexerRepository indexerRepository, IEnumerable<IIndexer> indexers, Logger logger)
|
||||
public IndexerService(IIndexerRepository indexerRepository, IEnumerable<Func<IIndexer>> indexers, Logger logger)
|
||||
{
|
||||
_indexerRepository = indexerRepository;
|
||||
_logger = logger;
|
||||
_indexers = indexers.ToList();
|
||||
}
|
||||
|
||||
|
||||
public List<Indexer> All()
|
||||
{
|
||||
return _indexerRepository.All().Select(ToIndexer).ToList();
|
||||
|
@ -47,10 +44,9 @@ namespace NzbDrone.Core.Indexers
|
|||
|
||||
public List<IIndexer> GetAvailableIndexers()
|
||||
{
|
||||
return All().Where(c => c.Enable && c.Settings.IsValid).Select(c=>c.Instance).ToList();
|
||||
return All().Where(c => c.Enable && c.Settings.IsValid).Select(c => c.Instance).ToList();
|
||||
}
|
||||
|
||||
|
||||
public Indexer Get(string name)
|
||||
{
|
||||
return ToIndexer(_indexerRepository.Get(name));
|
||||
|
@ -60,7 +56,7 @@ namespace NzbDrone.Core.Indexers
|
|||
private Indexer ToIndexer(IndexerDefinition definition)
|
||||
{
|
||||
var indexer = new Indexer();
|
||||
indexer.DefinitionId = definition.Id;
|
||||
indexer.Id = definition.Id;
|
||||
indexer.Enable = definition.Enable;
|
||||
indexer.Instance = GetInstance(definition);
|
||||
indexer.Name = definition.Name;
|
||||
|
@ -74,16 +70,13 @@ namespace NzbDrone.Core.Indexers
|
|||
indexer.Settings = NullSetting.Instance;
|
||||
}
|
||||
|
||||
|
||||
return indexer;
|
||||
}
|
||||
|
||||
private IIndexer GetInstance(IndexerDefinition indexerDefinition)
|
||||
{
|
||||
var existingInstance = _indexers.Single(c => c.GetType().Name.Equals(indexerDefinition.Implementation, StringComparison.CurrentCultureIgnoreCase));
|
||||
var instance = (IIndexer)Activator.CreateInstance(existingInstance.GetType());
|
||||
var instance = _indexers.Single(c => c().GetType().Name.Equals(indexerDefinition.Implementation, StringComparison.InvariantCultureIgnoreCase))();
|
||||
instance.InstanceDefinition = indexerDefinition;
|
||||
|
||||
return instance;
|
||||
}
|
||||
|
||||
|
@ -93,11 +86,7 @@ namespace NzbDrone.Core.Indexers
|
|||
|
||||
if (!All().Any())
|
||||
{
|
||||
var definitions = _indexers.SelectMany(delegate(IIndexer indexer)
|
||||
{
|
||||
return indexer.DefaultDefinitions;
|
||||
});
|
||||
|
||||
var definitions = _indexers.SelectMany(indexer => indexer().DefaultDefinitions);
|
||||
_indexerRepository.InsertMany(definitions.ToList());
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue