mirror of
https://github.com/lidarr/lidarr.git
synced 2025-08-23 06:45:19 -07:00
Add base for netimport api. Still nothing on the UI side.
This commit is contained in:
parent
4f37a36619
commit
2c52795822
3 changed files with 112 additions and 0 deletions
32
src/NzbDrone.Api/NetImport/NetImportModule.cs
Normal file
32
src/NzbDrone.Api/NetImport/NetImportModule.cs
Normal file
|
@ -0,0 +1,32 @@
|
|||
using NzbDrone.Core.NetImport;
|
||||
|
||||
namespace NzbDrone.Api.NetImport
|
||||
{
|
||||
public class NetImportModule : ProviderModuleBase<NetImportResource, INetImport, NetImportDefinition>
|
||||
{
|
||||
public NetImportModule(NetImportFactory indexerFactory)
|
||||
: base(indexerFactory, "indexer")
|
||||
{
|
||||
}
|
||||
|
||||
protected override void MapToResource(NetImportResource resource, NetImportDefinition definition)
|
||||
{
|
||||
base.MapToResource(resource, definition);
|
||||
|
||||
resource.Enabled = definition.Enabled;
|
||||
}
|
||||
|
||||
protected override void MapToModel(NetImportDefinition definition, NetImportResource resource)
|
||||
{
|
||||
base.MapToModel(definition, resource);
|
||||
|
||||
resource.Enabled = definition.Enabled;
|
||||
}
|
||||
|
||||
protected override void Validate(NetImportDefinition definition, bool includeWarnings)
|
||||
{
|
||||
if (!definition.Enable) return;
|
||||
base.Validate(definition, includeWarnings);
|
||||
}
|
||||
}
|
||||
}
|
10
src/NzbDrone.Api/NetImport/NetImportResource.cs
Normal file
10
src/NzbDrone.Api/NetImport/NetImportResource.cs
Normal file
|
@ -0,0 +1,10 @@
|
|||
using NzbDrone.Core.NetImport;
|
||||
|
||||
namespace NzbDrone.Api.NetImport
|
||||
{
|
||||
public class NetImportResource : ProviderResource
|
||||
{
|
||||
public bool Enabled { get; set; }
|
||||
public bool EnableSearch { get; set; }
|
||||
}
|
||||
}
|
70
src/NzbDrone.Core/NetImport/NetImportFactory.cs
Normal file
70
src/NzbDrone.Core/NetImport/NetImportFactory.cs
Normal file
|
@ -0,0 +1,70 @@
|
|||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using NLog;
|
||||
using NzbDrone.Common.Composition;
|
||||
using NzbDrone.Core.Messaging.Events;
|
||||
using NzbDrone.Core.ThingiProvider;
|
||||
|
||||
namespace NzbDrone.Core.NetImport
|
||||
{
|
||||
public interface INetImportFactory : IProviderFactory<INetImport, NetImportDefinition>
|
||||
{
|
||||
List<INetImport> Enabled();
|
||||
}
|
||||
|
||||
public class NetImportFactory : ProviderFactory<INetImport, NetImportDefinition>, INetImportFactory
|
||||
{
|
||||
//private readonly IIndexerStatusService _indexerStatusService;
|
||||
private readonly INetImportRepository _providerRepository;
|
||||
private readonly Logger _logger;
|
||||
|
||||
public NetImportFactory(//IIndexerStatusService indexerStatusService,
|
||||
INetImportRepository providerRepository,
|
||||
IEnumerable<INetImport> providers,
|
||||
IContainer container,
|
||||
IEventAggregator eventAggregator,
|
||||
Logger logger)
|
||||
: base(providerRepository, providers, container, eventAggregator, logger)
|
||||
{
|
||||
//_indexerStatusService = indexerStatusService;
|
||||
_providerRepository = providerRepository;
|
||||
_logger = logger;
|
||||
}
|
||||
|
||||
protected override List<NetImportDefinition> Active()
|
||||
{
|
||||
return base.Active().Where(c => c.Enabled).ToList();
|
||||
}
|
||||
|
||||
public override void SetProviderCharacteristics(INetImport provider, NetImportDefinition definition)
|
||||
{
|
||||
base.SetProviderCharacteristics(provider, definition);
|
||||
}
|
||||
|
||||
public List<INetImport> Enabled()
|
||||
{
|
||||
var enabledIndexers = GetAvailableProviders().Where(n => ((NetImportDefinition)n.Definition).Enabled);
|
||||
|
||||
var indexers = FilterBlockedIndexers(enabledIndexers);
|
||||
|
||||
return indexers.ToList();
|
||||
}
|
||||
|
||||
private IEnumerable<INetImport> FilterBlockedIndexers(IEnumerable<INetImport> indexers)
|
||||
{
|
||||
//var blockedIndexers = _indexerStatusService.GetBlockedIndexers().ToDictionary(v => v.IndexerId, v => v);
|
||||
|
||||
foreach (var indexer in indexers)
|
||||
{
|
||||
/*IndexerStatus blockedIndexerStatus;
|
||||
if (blockedIndexers.TryGetValue(indexer.Definition.Id, out blockedIndexerStatus))
|
||||
{
|
||||
_logger.Debug("Temporarily ignoring indexer {0} till {1} due to recent failures.", indexer.Definition.Name, blockedIndexerStatus.DisabledTill.Value.ToLocalTime());
|
||||
continue;
|
||||
}*/
|
||||
|
||||
yield return indexer;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue