2015-07-19 00:27:41 +00:00
|
|
|
|
using Autofac;
|
2015-07-19 13:22:50 +00:00
|
|
|
|
using Jackett.Indexers;
|
2015-07-19 00:27:41 +00:00
|
|
|
|
using Jackett.Models;
|
2015-07-19 17:37:08 +00:00
|
|
|
|
using Jackett.Utils;
|
2015-07-28 19:22:23 +00:00
|
|
|
|
using Jackett.Utils.Clients;
|
2015-07-19 00:59:30 +00:00
|
|
|
|
using Newtonsoft.Json.Linq;
|
2015-07-19 00:27:41 +00:00
|
|
|
|
using NLog;
|
|
|
|
|
using System;
|
|
|
|
|
using System.Collections.Generic;
|
|
|
|
|
using System.IO;
|
|
|
|
|
using System.Linq;
|
|
|
|
|
using System.Text;
|
|
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
|
|
|
|
|
namespace Jackett.Services
|
|
|
|
|
{
|
|
|
|
|
public interface IIndexerManagerService
|
|
|
|
|
{
|
2015-07-19 18:25:47 +00:00
|
|
|
|
Task TestIndexer(string name);
|
2015-07-19 00:27:41 +00:00
|
|
|
|
void DeleteIndexer(string name);
|
2015-07-19 13:22:50 +00:00
|
|
|
|
IIndexer GetIndexer(string name);
|
|
|
|
|
IEnumerable<IIndexer> GetAllIndexers();
|
|
|
|
|
void SaveConfig(IIndexer indexer, JToken obj);
|
|
|
|
|
void InitIndexers();
|
2016-10-27 07:30:03 +00:00
|
|
|
|
void InitCardigannIndexers(string path);
|
2015-07-19 00:27:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public class IndexerManagerService : IIndexerManagerService
|
|
|
|
|
{
|
|
|
|
|
private IContainer container;
|
|
|
|
|
private IConfigurationService configService;
|
|
|
|
|
private Logger logger;
|
2015-07-19 17:18:54 +00:00
|
|
|
|
private Dictionary<string, IIndexer> indexers = new Dictionary<string, IIndexer>();
|
2015-07-28 23:56:08 +00:00
|
|
|
|
private ICacheService cacheService;
|
2015-07-19 00:27:41 +00:00
|
|
|
|
|
2015-07-28 23:56:08 +00:00
|
|
|
|
public IndexerManagerService(IContainer c, IConfigurationService config, Logger l, ICacheService cache)
|
2015-07-19 00:27:41 +00:00
|
|
|
|
{
|
|
|
|
|
container = c;
|
|
|
|
|
configService = config;
|
|
|
|
|
logger = l;
|
2015-07-28 23:56:08 +00:00
|
|
|
|
cacheService = cache;
|
2015-07-19 00:27:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
2016-10-27 07:30:03 +00:00
|
|
|
|
protected void LoadIndexerConfig(IIndexer idx)
|
|
|
|
|
{
|
|
|
|
|
var configFilePath = GetIndexerConfigFilePath(idx);
|
|
|
|
|
if (File.Exists(configFilePath))
|
|
|
|
|
{
|
|
|
|
|
var fileStr = File.ReadAllText(configFilePath);
|
|
|
|
|
var jsonString = JToken.Parse(fileStr);
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
idx.LoadFromSavedConfiguration(jsonString);
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
logger.Error(ex, "Failed loading configuration for {0}, you must reconfigure this indexer", idx.DisplayName);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2015-07-19 13:22:50 +00:00
|
|
|
|
public void InitIndexers()
|
2015-07-19 00:27:41 +00:00
|
|
|
|
{
|
2015-07-28 19:22:23 +00:00
|
|
|
|
logger.Info("Using HTTP Client: " + container.Resolve<IWebClient>().GetType().Name);
|
|
|
|
|
|
2016-10-27 07:30:03 +00:00
|
|
|
|
foreach (var idx in container.Resolve<IEnumerable<IIndexer>>().Where(p => p.ID != "cardigannindexer").OrderBy(_ => _.DisplayName))
|
2015-07-19 13:22:50 +00:00
|
|
|
|
{
|
2015-07-19 19:28:08 +00:00
|
|
|
|
indexers.Add(idx.ID, idx);
|
2016-10-27 07:30:03 +00:00
|
|
|
|
LoadIndexerConfig(idx);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void InitCardigannIndexers(string path)
|
|
|
|
|
{
|
|
|
|
|
logger.Info("Loading Cardigann definitions from: " + path);
|
|
|
|
|
|
|
|
|
|
DirectoryInfo d = new DirectoryInfo(path);
|
|
|
|
|
|
|
|
|
|
foreach (var file in d.GetFiles("*.yml"))
|
|
|
|
|
{
|
|
|
|
|
string DefinitionString = File.ReadAllText(file.FullName);
|
|
|
|
|
CardigannIndexer idx = new CardigannIndexer(this, container.Resolve<IWebClient>(), logger, container.Resolve<IProtectionService>(), DefinitionString);
|
|
|
|
|
if (indexers.ContainsKey(idx.ID))
|
|
|
|
|
{
|
|
|
|
|
logger.Debug(string.Format("Ignoring definition ID={0}, file={1}: Indexer already exists", idx.ID, file.FullName));
|
|
|
|
|
}
|
|
|
|
|
else
|
|
|
|
|
{
|
|
|
|
|
indexers.Add(idx.ID, idx);
|
|
|
|
|
LoadIndexerConfig(idx);
|
|
|
|
|
}
|
2015-07-19 13:22:50 +00:00
|
|
|
|
}
|
2015-07-19 00:27:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-07-19 13:22:50 +00:00
|
|
|
|
public IIndexer GetIndexer(string name)
|
2015-07-19 00:27:41 +00:00
|
|
|
|
{
|
2015-07-22 22:06:46 +00:00
|
|
|
|
if (indexers.ContainsKey(name))
|
2015-07-19 17:18:54 +00:00
|
|
|
|
{
|
2015-07-22 22:06:46 +00:00
|
|
|
|
return indexers[name];
|
2015-07-19 17:18:54 +00:00
|
|
|
|
}
|
|
|
|
|
else
|
2015-07-19 13:22:50 +00:00
|
|
|
|
{
|
|
|
|
|
logger.Error("Request for unknown indexer: " + name);
|
|
|
|
|
throw new Exception("Unknown indexer: " + name);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public IEnumerable<IIndexer> GetAllIndexers()
|
|
|
|
|
{
|
2015-07-19 17:18:54 +00:00
|
|
|
|
return indexers.Values;
|
2015-07-19 00:27:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-07-19 18:25:47 +00:00
|
|
|
|
public async Task TestIndexer(string name)
|
2015-07-19 00:27:41 +00:00
|
|
|
|
{
|
|
|
|
|
var indexer = GetIndexer(name);
|
|
|
|
|
var browseQuery = new TorznabQuery();
|
|
|
|
|
var results = await indexer.PerformQuery(browseQuery);
|
2015-08-13 21:51:49 +00:00
|
|
|
|
results = indexer.CleanLinks(results);
|
2015-07-28 23:10:04 +00:00
|
|
|
|
logger.Info(string.Format("Found {0} releases from {1}", results.Count(), indexer.DisplayName));
|
|
|
|
|
if (results.Count() == 0)
|
2015-07-19 00:27:41 +00:00
|
|
|
|
throw new Exception("Found no results while trying to browse this tracker");
|
2015-08-05 22:00:09 +00:00
|
|
|
|
cacheService.CacheRssResults(indexer, results);
|
2015-07-19 00:27:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void DeleteIndexer(string name)
|
|
|
|
|
{
|
|
|
|
|
var indexer = GetIndexer(name);
|
2015-07-19 17:18:54 +00:00
|
|
|
|
var configPath = GetIndexerConfigFilePath(indexer);
|
2015-07-19 00:27:41 +00:00
|
|
|
|
File.Delete(configPath);
|
2015-07-19 19:38:41 +00:00
|
|
|
|
indexers[name] = container.ResolveNamed<IIndexer>(indexer.ID);
|
2015-07-19 00:27:41 +00:00
|
|
|
|
}
|
|
|
|
|
|
2015-07-19 13:22:50 +00:00
|
|
|
|
private string GetIndexerConfigFilePath(IIndexer indexer)
|
2015-07-19 00:27:41 +00:00
|
|
|
|
{
|
2015-07-19 19:28:08 +00:00
|
|
|
|
return Path.Combine(configService.GetIndexerConfigDir(), indexer.ID + ".json");
|
2015-07-19 00:27:41 +00:00
|
|
|
|
}
|
2015-07-19 00:59:30 +00:00
|
|
|
|
|
2015-07-19 13:22:50 +00:00
|
|
|
|
public void SaveConfig(IIndexer indexer, JToken obj)
|
2015-07-19 00:59:30 +00:00
|
|
|
|
{
|
|
|
|
|
var configFilePath = GetIndexerConfigFilePath(indexer);
|
|
|
|
|
if (!Directory.Exists(configService.GetIndexerConfigDir()))
|
|
|
|
|
Directory.CreateDirectory(configService.GetIndexerConfigDir());
|
|
|
|
|
File.WriteAllText(configFilePath, obj.ToString());
|
|
|
|
|
}
|
2015-07-19 00:27:41 +00:00
|
|
|
|
}
|
|
|
|
|
}
|