2013-05-19 16:17:32 -07:00
|
|
|
using NLog;
|
|
|
|
using NzbDrone.Core.Tv;
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Notifications.Xbmc
|
|
|
|
{
|
2013-05-19 19:43:22 -07:00
|
|
|
public class Xbmc : NotificationBase<XbmcSettings>
|
2013-05-19 16:17:32 -07:00
|
|
|
{
|
2013-06-11 23:45:25 -07:00
|
|
|
private readonly IXbmcService _xbmcProvider;
|
2013-05-19 16:17:32 -07:00
|
|
|
|
2013-06-11 23:45:25 -07:00
|
|
|
public Xbmc(IXbmcService xbmcProvider, Logger logger)
|
2013-05-19 16:17:32 -07:00
|
|
|
{
|
|
|
|
_xbmcProvider = xbmcProvider;
|
|
|
|
}
|
|
|
|
|
|
|
|
public override string Name
|
|
|
|
{
|
|
|
|
get { return "XBMC"; }
|
2013-06-12 23:41:26 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
public override string ImplementationName
|
|
|
|
{
|
|
|
|
get { return "XBMC"; }
|
2013-05-19 16:17:32 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
public override void OnGrab(string message)
|
|
|
|
{
|
|
|
|
const string header = "NzbDrone [TV] - Grabbed";
|
|
|
|
|
2013-05-19 21:19:54 -07:00
|
|
|
if (Settings.Notify)
|
|
|
|
{
|
|
|
|
_xbmcProvider.Notify(Settings, header, message);
|
|
|
|
}
|
2013-05-19 16:17:32 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
public override void OnDownload(string message, Series series)
|
|
|
|
{
|
|
|
|
const string header = "NzbDrone [TV] - Downloaded";
|
|
|
|
|
2013-05-19 21:19:54 -07:00
|
|
|
if (Settings.Notify)
|
|
|
|
{
|
|
|
|
_xbmcProvider.Notify(Settings, header, message);
|
|
|
|
}
|
|
|
|
|
2013-05-19 16:17:32 -07:00
|
|
|
UpdateAndClean(series);
|
|
|
|
}
|
|
|
|
|
|
|
|
public override void AfterRename(Series series)
|
|
|
|
{
|
|
|
|
UpdateAndClean(series);
|
|
|
|
}
|
|
|
|
|
|
|
|
private void UpdateAndClean(Series series)
|
|
|
|
{
|
|
|
|
if (Settings.UpdateLibrary)
|
|
|
|
{
|
|
|
|
_xbmcProvider.Update(Settings, series);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (Settings.CleanLibrary)
|
|
|
|
{
|
|
|
|
_xbmcProvider.Clean(Settings);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|