Fixed: Report certificate validation failures when configuring Plex Media Server connection

Closes #4781
pull/4793/head
Mark McDowall 3 years ago
parent 0ac0a6223a
commit ec62884649

@ -195,7 +195,12 @@ namespace NzbDrone.Core.Notifications.Plex.Server
} }
catch (WebException ex) catch (WebException ex)
{ {
throw new PlexException("Unable to connect to Plex Media Server", ex); if (ex.Status == WebExceptionStatus.TrustFailure)
{
throw new PlexException("Unable to connect to Plex Media Server, certificate validation failed.", ex);
}
throw new PlexException($"Unable to connect to Plex Media Server, {ex.Message}", ex);
} }
return response.Content; return response.Content;

@ -8,6 +8,7 @@ using NLog;
using NzbDrone.Common.Cache; using NzbDrone.Common.Cache;
using NzbDrone.Common.Extensions; using NzbDrone.Common.Extensions;
using NzbDrone.Core.Tv; using NzbDrone.Core.Tv;
using NzbDrone.Core.Validation;
namespace NzbDrone.Core.Notifications.Plex.Server namespace NzbDrone.Core.Notifications.Plex.Server
{ {
@ -191,15 +192,23 @@ namespace NzbDrone.Core.Notifications.Plex.Server
return new ValidationFailure("Host", "At least one TV library is required"); return new ValidationFailure("Host", "At least one TV library is required");
} }
} }
catch(PlexAuthenticationException ex) catch (PlexAuthenticationException ex)
{ {
_logger.Error(ex, "Unable to connect to Plex Server"); _logger.Error(ex, "Unable to connect to Plex Media Server");
return new ValidationFailure("AuthToken", "Invalid authentication token"); return new ValidationFailure("AuthToken", "Invalid authentication token");
} }
catch (PlexException ex)
{
return new NzbDroneValidationFailure("Host", ex.Message);
}
catch (Exception ex) catch (Exception ex)
{ {
_logger.Error(ex, "Unable to connect to Plex Server"); _logger.Error(ex, "Unable to connect to Plex Media Server");
return new ValidationFailure("Host", "Unable to connect to Plex Server");
return new NzbDroneValidationFailure("Host", "Unable to connect to Plex Media Server")
{
DetailedDescription = ex.Message
};
} }
return null; return null;

Loading…
Cancel
Save