@ -3,6 +3,8 @@ using System.Collections.Generic;
using FluentValidation.Results ;
using NLog ;
using NzbDrone.Common.Extensions ;
using NzbDrone.Common.Http ;
using NzbDrone.Common.Serializer ;
using NzbDrone.Core.Notifications.Slack.Payloads ;
using NzbDrone.Core.Rest ;
using NzbDrone.Core.Tv ;
@ -14,10 +16,12 @@ namespace NzbDrone.Core.Notifications.Slack
{
public class Slack : NotificationBase < SlackSettings >
{
private readonly ISlackProxy _proxy ;
private readonly Logger _logger ;
public Slack ( Logger logger )
public Slack ( ISlackProxy proxy , Logger logger )
{
_proxy = proxy ;
_logger = logger ;
}
@ -27,12 +31,7 @@ namespace NzbDrone.Core.Notifications.Slack
public override void OnGrab ( GrabMessage message )
{
var payload = new SlackPayload
{
IconEmoji = Settings . Icon ,
Username = Settings . Username ,
Text = $"Grabbed: {message.Message}" ,
Attachments = new List < Attachment >
var attachments = new List < Attachment >
{
new Attachment
{
@ -41,20 +40,15 @@ namespace NzbDrone.Core.Notifications.Slack
Text = message . Message ,
Color = "warning"
}
}
} ;
var payload = CreatePayload ( $"Grabbed: {message.Message}" , attachments ) ;
NotifySlack( payload ) ;
_proxy. SendPayload ( payload , Settings ) ;
}
public override void OnDownload ( DownloadMessage message )
{
var payload = new SlackPayload
{
IconEmoji = Settings . Icon ,
Username = Settings . Username ,
Text = $"Imported: {message.Message}" ,
Attachments = new List < Attachment >
var attachments = new List < Attachment >
{
new Attachment
{
@ -63,48 +57,40 @@ namespace NzbDrone.Core.Notifications.Slack
Text = message . Message ,
Color = "good"
}
}
} ;
var payload = CreatePayload ( $"Imported: {message.Message}" , attachments ) ;
NotifySlack( payload ) ;
_proxy. SendPayload ( payload , Settings ) ;
}
public override void OnMovieRename ( Movie movie )
{
var payload = new SlackPayload
{
IconEmoji = Settings . Icon ,
Username = Settings . Username ,
Text = "Renamed" ,
Attachments = new List < Attachment >
var attachments = new List < Attachment >
{
new Attachment
{
Title = movie . Title ,
}
}
} ;
NotifySlack ( payload ) ;
var payload = CreatePayload ( "Renamed" , attachments ) ;
_proxy . SendPayload ( payload , Settings ) ;
}
public override void OnRename ( Series series )
{
var payload = new SlackPayload
{
IconEmoji = Settings . Icon ,
Username = Settings . Username ,
Text = "Renamed" ,
Attachments = new List < Attachment >
var attachments = new List < Attachment >
{
new Attachment
{
Title = series . Title ,
}
}
} ;
NotifySlack ( payload ) ;
var payload = CreatePayload ( "Renamed" , attachments ) ;
_proxy . SendPayload ( payload , Settings ) ;
}
public override ValidationResult Test ( )
@ -121,14 +107,10 @@ namespace NzbDrone.Core.Notifications.Slack
try
{
var message = $"Test message from Radarr posted at {DateTime.Now}" ;
var payload = new SlackPayload
{
IconEmoji = Settings . Icon ,
Username = Settings . Username ,
Text = message
} ;
NotifySlack ( payload ) ;
var payload = CreatePayload ( message ) ;
_proxy . SendPayload ( payload , Settings ) ;
}
catch ( SlackExeption ex )
@ -139,24 +121,31 @@ namespace NzbDrone.Core.Notifications.Slack
return null ;
}
private void NotifySlack ( SlackPayload payload )
{
try
private SlackPayload CreatePayload ( string message , List < Attachment > attachments = null )
{
var client = RestClientFactory . BuildClient ( Settings . WebHookUrl ) ;
var request = new RestRequest ( Method . POST )
var icon = Settings . Icon ;
var payload = new SlackPayload
{
RequestFormat = DataFormat . Json ,
JsonSerializer = new JsonNetSerializer ( )
Username = Settings . Username ,
Text = message ,
Attachments = attachments
} ;
request . AddBody ( payload ) ;
client . ExecuteAndValidate ( request ) ;
if ( icon . IsNotNullOrWhiteSpace ( ) )
{
// Set the correct icon based on the value
if ( icon . StartsWith ( ":" ) & & icon . EndsWith ( ":" ) )
{
payload . IconEmoji = icon ;
}
catch ( RestException ex )
el se
{
_logger . Error ( ex , "Unable to post payload {0}" , payload ) ;
throw new SlackExeption ( "Unable to post payload" , ex ) ;
payload . IconUrl = icon ;
}
}
return payload ;
}
}
}