2012-02-21 23:10:42 +00:00
|
|
|
|
using System;
|
|
|
|
|
using NLog;
|
2013-02-24 06:48:52 +00:00
|
|
|
|
using NzbDrone.Core.Configuration;
|
2013-02-19 06:01:03 +00:00
|
|
|
|
using NzbDrone.Core.Tv;
|
2012-02-21 23:10:42 +00:00
|
|
|
|
using NzbDrone.Core.Providers.Core;
|
|
|
|
|
using NzbDrone.Core.Repository;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Providers.ExternalNotification
|
|
|
|
|
{
|
|
|
|
|
public class Plex : ExternalNotificationBase
|
|
|
|
|
{
|
|
|
|
|
private readonly PlexProvider _plexProvider;
|
|
|
|
|
|
2013-02-24 06:48:52 +00:00
|
|
|
|
public Plex(IConfigService configService, PlexProvider plexProvider)
|
|
|
|
|
: base(configService)
|
2012-02-21 23:10:42 +00:00
|
|
|
|
{
|
|
|
|
|
_plexProvider = plexProvider;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override string Name
|
|
|
|
|
{
|
|
|
|
|
get { return "Plex"; }
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void OnGrab(string message)
|
|
|
|
|
{
|
|
|
|
|
const string header = "NzbDrone [TV] - Grabbed";
|
|
|
|
|
|
2013-02-24 06:48:52 +00:00
|
|
|
|
if (_configService.PlexNotifyOnGrab)
|
2012-02-21 23:10:42 +00:00
|
|
|
|
{
|
|
|
|
|
_logger.Trace("Sending Notification to Plex Clients");
|
|
|
|
|
_plexProvider.Notify(header, message);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void OnDownload(string message, Series series)
|
|
|
|
|
{
|
|
|
|
|
const string header = "NzbDrone [TV] - Downloaded";
|
|
|
|
|
|
2013-02-24 06:48:52 +00:00
|
|
|
|
if (_configService.PlexNotifyOnDownload)
|
2012-02-21 23:10:42 +00:00
|
|
|
|
{
|
|
|
|
|
_logger.Trace("Sending Notification to Plex Clients");
|
|
|
|
|
_plexProvider.Notify(header, message);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
UpdateIfEnabled();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void OnRename(string message, Series series)
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public override void AfterRename(string message, Series series)
|
|
|
|
|
{
|
|
|
|
|
UpdateIfEnabled();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private void UpdateIfEnabled()
|
|
|
|
|
{
|
2013-02-24 06:48:52 +00:00
|
|
|
|
if (_configService.PlexUpdateLibrary)
|
2012-02-21 23:10:42 +00:00
|
|
|
|
{
|
|
|
|
|
_logger.Trace("Sending Update Request to Plex Server");
|
|
|
|
|
_plexProvider.UpdateLibrary();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|