Radarr/src/NzbDrone.Core/Notifications/MediaBrowser/MediaBrowserService.cs

71 lines
2.1 KiB
C#
Raw Normal View History

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
{
void Notify(MediaBrowserSettings settings, string title, string message);
2014-08-03 07:26:55 +00:00
void Update(MediaBrowserSettings settings, Series series);
void UpdateMovies(MediaBrowserSettings settings, Movie movie);
2014-08-03 07:26:55 +00:00
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;
}
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 void UpdateMovies(MediaBrowserSettings settings, Movie movie)
{
_proxy.UpdateMovies(settings, movie.ImdbId);
}
2014-08-03 07:26:55 +00:00
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)
{
2016-02-11 21:13:42 +00:00
_logger.Error(ex, "Unable to send test message: " + ex.Message);
2014-08-03 07:26:55 +00:00
return new ValidationFailure("Host", "Unable to send test message: " + ex.Message);
}
return null;
}
}
}