New: Add series tags to Webhook and Notifiarr events
This commit is contained in:
parent
f50a263f4f
commit
cc0a284660
|
@ -74,7 +74,7 @@ namespace NzbDrone.Core.Notifications.CustomScript
|
||||||
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
||||||
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
||||||
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
||||||
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", series.Tags.Select(t => _tagRepository.Get(t).Label)));
|
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", GetTagLabels(series)));
|
||||||
environmentVariables.Add("Sonarr_Release_EpisodeCount", remoteEpisode.Episodes.Count.ToString());
|
environmentVariables.Add("Sonarr_Release_EpisodeCount", remoteEpisode.Episodes.Count.ToString());
|
||||||
environmentVariables.Add("Sonarr_Release_SeasonNumber", remoteEpisode.Episodes.First().SeasonNumber.ToString());
|
environmentVariables.Add("Sonarr_Release_SeasonNumber", remoteEpisode.Episodes.First().SeasonNumber.ToString());
|
||||||
environmentVariables.Add("Sonarr_Release_EpisodeNumbers", string.Join(",", remoteEpisode.Episodes.Select(e => e.EpisodeNumber)));
|
environmentVariables.Add("Sonarr_Release_EpisodeNumbers", string.Join(",", remoteEpisode.Episodes.Select(e => e.EpisodeNumber)));
|
||||||
|
@ -121,7 +121,7 @@ namespace NzbDrone.Core.Notifications.CustomScript
|
||||||
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
||||||
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
||||||
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
||||||
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", series.Tags.Select(t => _tagRepository.Get(t).Label)));
|
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", GetTagLabels(series)));
|
||||||
environmentVariables.Add("Sonarr_EpisodeFile_Id", episodeFile.Id.ToString());
|
environmentVariables.Add("Sonarr_EpisodeFile_Id", episodeFile.Id.ToString());
|
||||||
environmentVariables.Add("Sonarr_EpisodeFile_EpisodeCount", episodeFile.Episodes.Value.Count.ToString());
|
environmentVariables.Add("Sonarr_EpisodeFile_EpisodeCount", episodeFile.Episodes.Value.Count.ToString());
|
||||||
environmentVariables.Add("Sonarr_EpisodeFile_RelativePath", episodeFile.RelativePath);
|
environmentVariables.Add("Sonarr_EpisodeFile_RelativePath", episodeFile.RelativePath);
|
||||||
|
@ -186,7 +186,7 @@ namespace NzbDrone.Core.Notifications.CustomScript
|
||||||
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
||||||
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
||||||
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
||||||
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", series.Tags.Select(t => _tagRepository.Get(t).Label)));
|
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", GetTagLabels(series)));
|
||||||
environmentVariables.Add("Sonarr_EpisodeFile_Ids", string.Join(",", renamedFiles.Select(e => e.EpisodeFile.Id)));
|
environmentVariables.Add("Sonarr_EpisodeFile_Ids", string.Join(",", renamedFiles.Select(e => e.EpisodeFile.Id)));
|
||||||
environmentVariables.Add("Sonarr_EpisodeFile_RelativePaths", string.Join("|", renamedFiles.Select(e => e.EpisodeFile.RelativePath)));
|
environmentVariables.Add("Sonarr_EpisodeFile_RelativePaths", string.Join("|", renamedFiles.Select(e => e.EpisodeFile.RelativePath)));
|
||||||
environmentVariables.Add("Sonarr_EpisodeFile_Paths", string.Join("|", renamedFiles.Select(e => e.EpisodeFile.Path)));
|
environmentVariables.Add("Sonarr_EpisodeFile_Paths", string.Join("|", renamedFiles.Select(e => e.EpisodeFile.Path)));
|
||||||
|
@ -218,7 +218,7 @@ namespace NzbDrone.Core.Notifications.CustomScript
|
||||||
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
||||||
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
||||||
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
||||||
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", series.Tags.Select(t => _tagRepository.Get(t).Label)));
|
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", GetTagLabels(series)));
|
||||||
environmentVariables.Add("Sonarr_EpisodeFile_Id", episodeFile.Id.ToString());
|
environmentVariables.Add("Sonarr_EpisodeFile_Id", episodeFile.Id.ToString());
|
||||||
environmentVariables.Add("Sonarr_EpisodeFile_EpisodeCount", episodeFile.Episodes.Value.Count.ToString());
|
environmentVariables.Add("Sonarr_EpisodeFile_EpisodeCount", episodeFile.Episodes.Value.Count.ToString());
|
||||||
environmentVariables.Add("Sonarr_EpisodeFile_RelativePath", episodeFile.RelativePath);
|
environmentVariables.Add("Sonarr_EpisodeFile_RelativePath", episodeFile.RelativePath);
|
||||||
|
@ -257,7 +257,7 @@ namespace NzbDrone.Core.Notifications.CustomScript
|
||||||
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
||||||
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
||||||
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
||||||
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", series.Tags.Select(t => _tagRepository.Get(t).Label)));
|
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", GetTagLabels(series)));
|
||||||
|
|
||||||
ExecuteScript(environmentVariables);
|
ExecuteScript(environmentVariables);
|
||||||
}
|
}
|
||||||
|
@ -281,7 +281,7 @@ namespace NzbDrone.Core.Notifications.CustomScript
|
||||||
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
||||||
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
||||||
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
||||||
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", series.Tags.Select(t => _tagRepository.Get(t).Label)));
|
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", GetTagLabels(series)));
|
||||||
environmentVariables.Add("Sonarr_Series_DeletedFiles", deleteMessage.DeletedFiles.ToString());
|
environmentVariables.Add("Sonarr_Series_DeletedFiles", deleteMessage.DeletedFiles.ToString());
|
||||||
|
|
||||||
ExecuteScript(environmentVariables);
|
ExecuteScript(environmentVariables);
|
||||||
|
@ -350,7 +350,7 @@ namespace NzbDrone.Core.Notifications.CustomScript
|
||||||
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
environmentVariables.Add("Sonarr_Series_Year", series.Year.ToString());
|
||||||
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
environmentVariables.Add("Sonarr_Series_OriginalLanguage", IsoLanguages.Get(series.OriginalLanguage).ThreeLetterCode);
|
||||||
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
environmentVariables.Add("Sonarr_Series_Genres", string.Join("|", series.Genres));
|
||||||
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", series.Tags.Select(t => _tagRepository.Get(t).Label)));
|
environmentVariables.Add("Sonarr_Series_Tags", string.Join("|", GetTagLabels(series)));
|
||||||
environmentVariables.Add("Sonarr_Download_Client", message.DownloadClientInfo?.Name ?? string.Empty);
|
environmentVariables.Add("Sonarr_Download_Client", message.DownloadClientInfo?.Name ?? string.Empty);
|
||||||
environmentVariables.Add("Sonarr_Download_Client_Type", message.DownloadClientInfo?.Type ?? string.Empty);
|
environmentVariables.Add("Sonarr_Download_Client_Type", message.DownloadClientInfo?.Type ?? string.Empty);
|
||||||
environmentVariables.Add("Sonarr_Download_Id", message.DownloadId ?? string.Empty);
|
environmentVariables.Add("Sonarr_Download_Id", message.DownloadId ?? string.Empty);
|
||||||
|
@ -411,5 +411,14 @@ namespace NzbDrone.Core.Notifications.CustomScript
|
||||||
{
|
{
|
||||||
return possibleParent.IsParentPath(path);
|
return possibleParent.IsParentPath(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private List<string> GetTagLabels(Series series)
|
||||||
|
{
|
||||||
|
return _tagRepository.GetTags(series.Tags)
|
||||||
|
.Select(s => s.Label)
|
||||||
|
.Where(l => l.IsNotNullOrWhiteSpace())
|
||||||
|
.OrderBy(l => l)
|
||||||
|
.ToList();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,6 +5,7 @@ using NzbDrone.Core.Configuration;
|
||||||
using NzbDrone.Core.Localization;
|
using NzbDrone.Core.Localization;
|
||||||
using NzbDrone.Core.MediaFiles;
|
using NzbDrone.Core.MediaFiles;
|
||||||
using NzbDrone.Core.Notifications.Webhook;
|
using NzbDrone.Core.Notifications.Webhook;
|
||||||
|
using NzbDrone.Core.Tags;
|
||||||
using NzbDrone.Core.Tv;
|
using NzbDrone.Core.Tv;
|
||||||
using NzbDrone.Core.Validation;
|
using NzbDrone.Core.Validation;
|
||||||
|
|
||||||
|
@ -14,8 +15,8 @@ namespace NzbDrone.Core.Notifications.Notifiarr
|
||||||
{
|
{
|
||||||
private readonly INotifiarrProxy _proxy;
|
private readonly INotifiarrProxy _proxy;
|
||||||
|
|
||||||
public Notifiarr(INotifiarrProxy proxy, IConfigFileProvider configFileProvider, IConfigService configService, ILocalizationService localizationService)
|
public Notifiarr(INotifiarrProxy proxy, IConfigFileProvider configFileProvider, IConfigService configService, ILocalizationService localizationService, ITagRepository tagRepository)
|
||||||
: base(configFileProvider, configService, localizationService)
|
: base(configFileProvider, configService, localizationService, tagRepository)
|
||||||
{
|
{
|
||||||
_proxy = proxy;
|
_proxy = proxy;
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,6 +4,7 @@ using NzbDrone.Common.Extensions;
|
||||||
using NzbDrone.Core.Configuration;
|
using NzbDrone.Core.Configuration;
|
||||||
using NzbDrone.Core.Localization;
|
using NzbDrone.Core.Localization;
|
||||||
using NzbDrone.Core.MediaFiles;
|
using NzbDrone.Core.MediaFiles;
|
||||||
|
using NzbDrone.Core.Tags;
|
||||||
using NzbDrone.Core.Tv;
|
using NzbDrone.Core.Tv;
|
||||||
using NzbDrone.Core.Validation;
|
using NzbDrone.Core.Validation;
|
||||||
|
|
||||||
|
@ -13,8 +14,8 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
{
|
{
|
||||||
private readonly IWebhookProxy _proxy;
|
private readonly IWebhookProxy _proxy;
|
||||||
|
|
||||||
public Webhook(IWebhookProxy proxy, IConfigFileProvider configFileProvider, IConfigService configService, ILocalizationService localizationService)
|
public Webhook(IWebhookProxy proxy, IConfigFileProvider configFileProvider, IConfigService configService, ILocalizationService localizationService, ITagRepository tagRepository)
|
||||||
: base(configFileProvider, configService, localizationService)
|
: base(configFileProvider, configService, localizationService, tagRepository)
|
||||||
{
|
{
|
||||||
_proxy = proxy;
|
_proxy = proxy;
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,9 +1,11 @@
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using NzbDrone.Common.Extensions;
|
||||||
using NzbDrone.Core.Configuration;
|
using NzbDrone.Core.Configuration;
|
||||||
using NzbDrone.Core.Localization;
|
using NzbDrone.Core.Localization;
|
||||||
using NzbDrone.Core.MediaFiles;
|
using NzbDrone.Core.MediaFiles;
|
||||||
|
using NzbDrone.Core.Tags;
|
||||||
using NzbDrone.Core.ThingiProvider;
|
using NzbDrone.Core.ThingiProvider;
|
||||||
using NzbDrone.Core.Tv;
|
using NzbDrone.Core.Tv;
|
||||||
|
|
||||||
|
@ -15,12 +17,14 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
private readonly IConfigFileProvider _configFileProvider;
|
private readonly IConfigFileProvider _configFileProvider;
|
||||||
private readonly IConfigService _configService;
|
private readonly IConfigService _configService;
|
||||||
protected readonly ILocalizationService _localizationService;
|
protected readonly ILocalizationService _localizationService;
|
||||||
|
private readonly ITagRepository _tagRepository;
|
||||||
|
|
||||||
protected WebhookBase(IConfigFileProvider configFileProvider, IConfigService configService, ILocalizationService localizationService)
|
protected WebhookBase(IConfigFileProvider configFileProvider, IConfigService configService, ILocalizationService localizationService, ITagRepository tagRepository)
|
||||||
{
|
{
|
||||||
_configFileProvider = configFileProvider;
|
_configFileProvider = configFileProvider;
|
||||||
_configService = configService;
|
_configService = configService;
|
||||||
_localizationService = localizationService;
|
_localizationService = localizationService;
|
||||||
|
_tagRepository = tagRepository;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected WebhookGrabPayload BuildOnGrabPayload(GrabMessage message)
|
protected WebhookGrabPayload BuildOnGrabPayload(GrabMessage message)
|
||||||
|
@ -33,7 +37,7 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
EventType = WebhookEventType.Grab,
|
EventType = WebhookEventType.Grab,
|
||||||
InstanceName = _configFileProvider.InstanceName,
|
InstanceName = _configFileProvider.InstanceName,
|
||||||
ApplicationUrl = _configService.ApplicationUrl,
|
ApplicationUrl = _configService.ApplicationUrl,
|
||||||
Series = new WebhookSeries(message.Series),
|
Series = new WebhookSeries(message.Series, GetTagLabels(message.Series)),
|
||||||
Episodes = remoteEpisode.Episodes.ConvertAll(x => new WebhookEpisode(x)),
|
Episodes = remoteEpisode.Episodes.ConvertAll(x => new WebhookEpisode(x)),
|
||||||
Release = new WebhookRelease(quality, remoteEpisode),
|
Release = new WebhookRelease(quality, remoteEpisode),
|
||||||
DownloadClient = message.DownloadClientName,
|
DownloadClient = message.DownloadClientName,
|
||||||
|
@ -52,7 +56,7 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
EventType = WebhookEventType.Download,
|
EventType = WebhookEventType.Download,
|
||||||
InstanceName = _configFileProvider.InstanceName,
|
InstanceName = _configFileProvider.InstanceName,
|
||||||
ApplicationUrl = _configService.ApplicationUrl,
|
ApplicationUrl = _configService.ApplicationUrl,
|
||||||
Series = new WebhookSeries(message.Series),
|
Series = new WebhookSeries(message.Series, GetTagLabels(message.Series)),
|
||||||
Episodes = episodeFile.Episodes.Value.ConvertAll(x => new WebhookEpisode(x)),
|
Episodes = episodeFile.Episodes.Value.ConvertAll(x => new WebhookEpisode(x)),
|
||||||
EpisodeFile = new WebhookEpisodeFile(episodeFile),
|
EpisodeFile = new WebhookEpisodeFile(episodeFile),
|
||||||
Release = new WebhookGrabbedRelease(message.Release),
|
Release = new WebhookGrabbedRelease(message.Release),
|
||||||
|
@ -82,7 +86,7 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
EventType = WebhookEventType.EpisodeFileDelete,
|
EventType = WebhookEventType.EpisodeFileDelete,
|
||||||
InstanceName = _configFileProvider.InstanceName,
|
InstanceName = _configFileProvider.InstanceName,
|
||||||
ApplicationUrl = _configService.ApplicationUrl,
|
ApplicationUrl = _configService.ApplicationUrl,
|
||||||
Series = new WebhookSeries(deleteMessage.Series),
|
Series = new WebhookSeries(deleteMessage.Series, GetTagLabels(deleteMessage.Series)),
|
||||||
Episodes = deleteMessage.EpisodeFile.Episodes.Value.ConvertAll(x => new WebhookEpisode(x)),
|
Episodes = deleteMessage.EpisodeFile.Episodes.Value.ConvertAll(x => new WebhookEpisode(x)),
|
||||||
EpisodeFile = new WebhookEpisodeFile(deleteMessage.EpisodeFile),
|
EpisodeFile = new WebhookEpisodeFile(deleteMessage.EpisodeFile),
|
||||||
DeleteReason = deleteMessage.Reason
|
DeleteReason = deleteMessage.Reason
|
||||||
|
@ -96,7 +100,7 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
EventType = WebhookEventType.SeriesAdd,
|
EventType = WebhookEventType.SeriesAdd,
|
||||||
InstanceName = _configFileProvider.InstanceName,
|
InstanceName = _configFileProvider.InstanceName,
|
||||||
ApplicationUrl = _configService.ApplicationUrl,
|
ApplicationUrl = _configService.ApplicationUrl,
|
||||||
Series = new WebhookSeries(addMessage.Series),
|
Series = new WebhookSeries(addMessage.Series, GetTagLabels(addMessage.Series)),
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -107,7 +111,7 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
EventType = WebhookEventType.SeriesDelete,
|
EventType = WebhookEventType.SeriesDelete,
|
||||||
InstanceName = _configFileProvider.InstanceName,
|
InstanceName = _configFileProvider.InstanceName,
|
||||||
ApplicationUrl = _configService.ApplicationUrl,
|
ApplicationUrl = _configService.ApplicationUrl,
|
||||||
Series = new WebhookSeries(deleteMessage.Series),
|
Series = new WebhookSeries(deleteMessage.Series, GetTagLabels(deleteMessage.Series)),
|
||||||
DeletedFiles = deleteMessage.DeletedFiles
|
DeletedFiles = deleteMessage.DeletedFiles
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -119,7 +123,7 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
EventType = WebhookEventType.Rename,
|
EventType = WebhookEventType.Rename,
|
||||||
InstanceName = _configFileProvider.InstanceName,
|
InstanceName = _configFileProvider.InstanceName,
|
||||||
ApplicationUrl = _configService.ApplicationUrl,
|
ApplicationUrl = _configService.ApplicationUrl,
|
||||||
Series = new WebhookSeries(series),
|
Series = new WebhookSeries(series, GetTagLabels(series)),
|
||||||
RenamedEpisodeFiles = renamedFiles.ConvertAll(x => new WebhookRenamedEpisodeFile(x))
|
RenamedEpisodeFiles = renamedFiles.ConvertAll(x => new WebhookRenamedEpisodeFile(x))
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
@ -172,7 +176,7 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
EventType = WebhookEventType.ManualInteractionRequired,
|
EventType = WebhookEventType.ManualInteractionRequired,
|
||||||
InstanceName = _configFileProvider.InstanceName,
|
InstanceName = _configFileProvider.InstanceName,
|
||||||
ApplicationUrl = _configService.ApplicationUrl,
|
ApplicationUrl = _configService.ApplicationUrl,
|
||||||
Series = new WebhookSeries(message.Series),
|
Series = new WebhookSeries(message.Series, GetTagLabels(message.Series)),
|
||||||
Episodes = remoteEpisode.Episodes.ConvertAll(x => new WebhookEpisode(x)),
|
Episodes = remoteEpisode.Episodes.ConvertAll(x => new WebhookEpisode(x)),
|
||||||
DownloadInfo = new WebhookDownloadClientItem(quality, message.TrackedDownload.DownloadItem),
|
DownloadInfo = new WebhookDownloadClientItem(quality, message.TrackedDownload.DownloadItem),
|
||||||
DownloadClient = message.DownloadClientInfo?.Name,
|
DownloadClient = message.DownloadClientInfo?.Name,
|
||||||
|
@ -192,12 +196,13 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
EventType = WebhookEventType.Test,
|
EventType = WebhookEventType.Test,
|
||||||
InstanceName = _configFileProvider.InstanceName,
|
InstanceName = _configFileProvider.InstanceName,
|
||||||
ApplicationUrl = _configService.ApplicationUrl,
|
ApplicationUrl = _configService.ApplicationUrl,
|
||||||
Series = new WebhookSeries()
|
Series = new WebhookSeries
|
||||||
{
|
{
|
||||||
Id = 1,
|
Id = 1,
|
||||||
Title = "Test Title",
|
Title = "Test Title",
|
||||||
Path = "C:\\testpath",
|
Path = "C:\\testpath",
|
||||||
TvdbId = 1234
|
TvdbId = 1234,
|
||||||
|
Tags = new List<string> { "test-tag" }
|
||||||
},
|
},
|
||||||
Episodes = new List<WebhookEpisode>()
|
Episodes = new List<WebhookEpisode>()
|
||||||
{
|
{
|
||||||
|
@ -211,5 +216,14 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private List<string> GetTagLabels(Series series)
|
||||||
|
{
|
||||||
|
return _tagRepository.GetTags(series.Tags)
|
||||||
|
.Select(s => s.Label)
|
||||||
|
.Where(l => l.IsNotNullOrWhiteSpace())
|
||||||
|
.OrderBy(l => l)
|
||||||
|
.ToList();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
using System.Collections.Generic;
|
||||||
using NzbDrone.Core.Tv;
|
using NzbDrone.Core.Tv;
|
||||||
|
|
||||||
namespace NzbDrone.Core.Notifications.Webhook
|
namespace NzbDrone.Core.Notifications.Webhook
|
||||||
|
@ -13,12 +14,13 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
public string ImdbId { get; set; }
|
public string ImdbId { get; set; }
|
||||||
public SeriesTypes Type { get; set; }
|
public SeriesTypes Type { get; set; }
|
||||||
public int Year { get; set; }
|
public int Year { get; set; }
|
||||||
|
public List<string> Tags { get; set; }
|
||||||
|
|
||||||
public WebhookSeries()
|
public WebhookSeries()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
public WebhookSeries(Series series)
|
public WebhookSeries(Series series, List<string> tags)
|
||||||
{
|
{
|
||||||
Id = series.Id;
|
Id = series.Id;
|
||||||
Title = series.Title;
|
Title = series.Title;
|
||||||
|
@ -29,6 +31,7 @@ namespace NzbDrone.Core.Notifications.Webhook
|
||||||
ImdbId = series.ImdbId;
|
ImdbId = series.ImdbId;
|
||||||
Type = series.SeriesType;
|
Type = series.SeriesType;
|
||||||
Year = series.Year;
|
Year = series.Year;
|
||||||
|
Tags = tags;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
using System;
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
using NzbDrone.Core.Datastore;
|
using NzbDrone.Core.Datastore;
|
||||||
using NzbDrone.Core.Messaging.Events;
|
using NzbDrone.Core.Messaging.Events;
|
||||||
|
@ -9,6 +10,7 @@ namespace NzbDrone.Core.Tags
|
||||||
{
|
{
|
||||||
Tag GetByLabel(string label);
|
Tag GetByLabel(string label);
|
||||||
Tag FindByLabel(string label);
|
Tag FindByLabel(string label);
|
||||||
|
List<Tag> GetTags(HashSet<int> tagIds);
|
||||||
}
|
}
|
||||||
|
|
||||||
public class TagRepository : BasicRepository<Tag>, ITagRepository
|
public class TagRepository : BasicRepository<Tag>, ITagRepository
|
||||||
|
@ -34,5 +36,10 @@ namespace NzbDrone.Core.Tags
|
||||||
{
|
{
|
||||||
return Query(c => c.Label == label).SingleOrDefault();
|
return Query(c => c.Label == label).SingleOrDefault();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public List<Tag> GetTags(HashSet<int> tagIds)
|
||||||
|
{
|
||||||
|
return Query(t => tagIds.Contains(t.Id));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue