Better response if invalid JSON is received through the API

pull/3017/head
Mark McDowall 6 years ago
parent 7d131fbb3d
commit e325a5c27e

@ -30,7 +30,7 @@ namespace Sonarr.Http.Exceptions
if (content != null) if (content != null)
{ {
result = result + " :" + content; result = $"{result}: {content}";
} }
return result; return result;

@ -3,6 +3,7 @@ using System.Collections.Generic;
using System.Linq; using System.Linq;
using FluentValidation; using FluentValidation;
using Nancy; using Nancy;
using Newtonsoft.Json;
using NzbDrone.Core.Datastore; using NzbDrone.Core.Datastore;
using Sonarr.Http.Extensions; using Sonarr.Http.Extensions;
@ -194,8 +195,16 @@ namespace Sonarr.Http.REST
protected TResource ReadResourceFromRequest(bool skipValidate = false) protected TResource ReadResourceFromRequest(bool skipValidate = false)
{ {
//TODO: handle when request is null TResource resource;
var resource = Request.Body.FromJson<TResource>();
try
{
resource = Request.Body.FromJson<TResource>();
}
catch (JsonReaderException e)
{
throw new BadRequestException($"Invalid request body. {e.Message}");
}
if (resource == null) if (resource == null)
{ {

Loading…
Cancel
Save