2014-08-03 07:26:55 +00:00
|
|
|
|
using System;
|
|
|
|
|
using System.Net;
|
|
|
|
|
using FluentValidation.Results;
|
|
|
|
|
using NLog;
|
|
|
|
|
using NzbDrone.Core.Rest;
|
|
|
|
|
using NzbDrone.Core.Tv;
|
|
|
|
|
|
|
|
|
|
namespace NzbDrone.Core.Notifications.MediaBrowser
|
|
|
|
|
{
|
|
|
|
|
public interface IMediaBrowserService
|
|
|
|
|
{
|
2015-10-03 17:45:26 +00:00
|
|
|
|
void Notify(MediaBrowserSettings settings, string title, string message);
|
2014-08-03 07:26:55 +00:00
|
|
|
|
void Update(MediaBrowserSettings settings, Series series);
|
|
|
|
|
ValidationFailure Test(MediaBrowserSettings settings);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public class MediaBrowserService : IMediaBrowserService
|
|
|
|
|
{
|
|
|
|
|
private readonly MediaBrowserProxy _proxy;
|
|
|
|
|
private readonly Logger _logger;
|
|
|
|
|
|
|
|
|
|
public MediaBrowserService(MediaBrowserProxy proxy, Logger logger)
|
|
|
|
|
{
|
|
|
|
|
_proxy = proxy;
|
|
|
|
|
_logger = logger;
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-03 17:45:26 +00:00
|
|
|
|
public void Notify(MediaBrowserSettings settings, string title, string message)
|
2014-08-03 07:26:55 +00:00
|
|
|
|
{
|
|
|
|
|
_proxy.Notify(settings, title, message);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public void Update(MediaBrowserSettings settings, Series series)
|
|
|
|
|
{
|
|
|
|
|
_proxy.Update(settings, series.TvdbId);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public ValidationFailure Test(MediaBrowserSettings settings)
|
|
|
|
|
{
|
|
|
|
|
try
|
|
|
|
|
{
|
|
|
|
|
_logger.Debug("Testing connection to MediaBrowser: {0}", settings.Address);
|
|
|
|
|
|
|
|
|
|
Notify(settings, "Test from Sonarr", "Success! MediaBrowser has been successfully configured!");
|
|
|
|
|
}
|
|
|
|
|
catch (RestException ex)
|
|
|
|
|
{
|
|
|
|
|
if (ex.Response.StatusCode == HttpStatusCode.Unauthorized)
|
|
|
|
|
{
|
|
|
|
|
return new ValidationFailure("ApiKey", "API Key is incorrect");
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
catch (Exception ex)
|
|
|
|
|
{
|
|
|
|
|
_logger.ErrorException("Unable to send test message: " + ex.Message, ex);
|
|
|
|
|
return new ValidationFailure("Host", "Unable to send test message: " + ex.Message);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|