Radarr/src/NzbDrone.Core/Indexers/IndexerBase.cs

125 lines
4.3 KiB
C#
Raw Normal View History

using System;
2013-04-07 07:30:37 +00:00
using System.Collections.Generic;
using System.Linq;
using System.Text.RegularExpressions;
using System.Threading.Tasks;
using FluentValidation.Results;
using NLog;
using NzbDrone.Common.Extensions;
using NzbDrone.Common.Http;
using NzbDrone.Core.Configuration;
using NzbDrone.Core.IndexerSearch.Definitions;
using NzbDrone.Core.Languages;
using NzbDrone.Core.Parser;
using NzbDrone.Core.Parser.Model;
using NzbDrone.Core.ThingiProvider;
2013-04-07 07:30:37 +00:00
namespace NzbDrone.Core.Indexers
{
public abstract class IndexerBase<TSettings> : IIndexer
where TSettings : IIndexerSettings, new()
2013-04-07 07:30:37 +00:00
{
private static readonly Regex MultiRegex = new (@"[_. ](?<multi>multi)[_. ]", RegexOptions.Compiled | RegexOptions.IgnoreCase);
protected readonly IIndexerStatusService _indexerStatusService;
protected readonly IConfigService _configService;
protected readonly IParsingService _parsingService;
protected readonly Logger _logger;
2015-04-25 16:19:23 +00:00
public abstract string Name { get; }
public abstract DownloadProtocol Protocol { get; }
public int Priority { get; set; }
public abstract bool SupportsRss { get; }
public abstract bool SupportsSearch { get; }
public IndexerBase(IIndexerStatusService indexerStatusService, IConfigService configService, IParsingService parsingService, Logger logger)
{
_indexerStatusService = indexerStatusService;
_configService = configService;
_parsingService = parsingService;
_logger = logger;
}
2016-12-09 06:54:15 +00:00
public Type ConfigContract => typeof(TSettings);
2013-04-07 07:30:37 +00:00
2016-12-09 06:54:15 +00:00
public virtual ProviderMessage Message => null;
public virtual IEnumerable<ProviderDefinition> DefaultDefinitions
2013-04-07 07:30:37 +00:00
{
get
2013-04-07 07:30:37 +00:00
{
var config = (IProviderConfig)new TSettings();
yield return new IndexerDefinition
{
EnableRss = config.Validate().IsValid && SupportsRss,
EnableAutomaticSearch = config.Validate().IsValid && SupportsSearch,
EnableInteractiveSearch = config.Validate().IsValid && SupportsSearch,
Implementation = GetType().Name,
Settings = config
};
}
2013-04-07 07:30:37 +00:00
}
2013-10-13 02:46:36 +00:00
public virtual ProviderDefinition Definition { get; set; }
2016-08-10 18:45:48 +00:00
2019-12-22 22:08:53 +00:00
public virtual object RequestAction(string action, IDictionary<string, string> query)
{
return null;
}
2013-09-22 05:20:26 +00:00
2016-12-09 06:54:15 +00:00
protected TSettings Settings => (TSettings)Definition.Settings;
2013-09-22 05:20:26 +00:00
public abstract Task<IList<ReleaseInfo>> FetchRecent();
public abstract Task<IList<ReleaseInfo>> Fetch(MovieSearchCriteria searchCriteria);
public abstract HttpRequest GetDownloadRequest(string link);
protected virtual IList<ReleaseInfo> CleanupReleases(IEnumerable<ReleaseInfo> releases)
{
var result = releases.DistinctBy(v => v.Guid).ToList();
var settings = Definition.Settings as IIndexerSettings;
result.ForEach(c =>
{
// Use multi languages from setting if ReleaseInfo languages is empty
if (c.Languages.Empty() && MultiRegex.IsMatch(c.Title) && settings.MultiLanguages.Any())
{
c.Languages = settings.MultiLanguages.Select(i => (Language)i).ToList();
}
c.IndexerId = Definition.Id;
c.Indexer = Definition.Name;
c.DownloadProtocol = Protocol;
c.IndexerPriority = ((IndexerDefinition)Definition).Priority;
});
return result;
}
public ValidationResult Test()
{
var failures = new List<ValidationFailure>();
try
{
Test(failures).GetAwaiter().GetResult();
}
catch (Exception ex)
{
2016-02-11 21:13:42 +00:00
_logger.Error(ex, "Test aborted due to exception");
failures.Add(new ValidationFailure(string.Empty, "Test was aborted due to an error: " + ex.Message));
}
return new ValidationResult(failures);
}
protected abstract Task Test(List<ValidationFailure> failures);
2013-09-22 20:00:29 +00:00
public override string ToString()
{
return Definition.Name;
2013-09-22 20:00:29 +00:00
}
2013-04-07 07:30:37 +00:00
}
}