mirror of
https://github.com/lidarr/Lidarr
synced 2024-12-25 01:02:05 +00:00
da979639ba
Some RssFeed Parsing has been implemented, it does not currently download items, still need to perform a more verbose episode check.
36 lines
1.2 KiB
C#
36 lines
1.2 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text;
|
|
using System.Text.RegularExpressions;
|
|
|
|
namespace NzbDrone.Core.Model
|
|
{
|
|
public class NzbSiteModel
|
|
{
|
|
private static readonly IList<NzbSiteModel> Sites = new List<NzbSiteModel>
|
|
{
|
|
new NzbSiteModel {Name = "nzbmatrix", Url = "nzbmatrix.com", Pattern = @"\d{6,10}"},
|
|
new NzbSiteModel {Name = "nzbsDotOrg", Url = "nzbs.org", Pattern = @"\d{5,10}"},
|
|
new NzbSiteModel {Name = "nzbsrus", Url = "nzbsrus.com", Pattern = @"\d{6,10}"},
|
|
new NzbSiteModel {Name = "lilx", Url = "lilx.net", Pattern = @"\d{6,10}"},
|
|
};
|
|
|
|
public string Name { get; set; }
|
|
public string Pattern { get; set; }
|
|
public string Url { get; set; }
|
|
|
|
// TODO: use HttpUtility.ParseQueryString();
|
|
// https://nzbmatrix.com/api-nzb-download.php?id=626526
|
|
public string ParseId(string url)
|
|
{
|
|
return Regex.Match(url, Pattern).Value;
|
|
}
|
|
|
|
public static NzbSiteModel Parse(string url)
|
|
{
|
|
return Sites.Where(site => url.Contains(site.Url)).SingleOrDefault() ??
|
|
new NzbSiteModel { Name = "unknown", Pattern = @"\d{6,10}" };
|
|
}
|
|
}
|
|
}
|