Fixed: Error updating providers with ID missing from JSON

(cherry picked from commit c435fcd685cc97e98d14f747227eefd39e4d1164)
pull/5105/head
Bogdan 3 months ago
parent bd7d25f963
commit 9850823298

@ -86,9 +86,16 @@ namespace Lidarr.Api.V1
[RestPutById] [RestPutById]
[Consumes("application/json")] [Consumes("application/json")]
[Produces("application/json")] [Produces("application/json")]
public ActionResult<TProviderResource> UpdateProvider([FromBody] TProviderResource providerResource, [FromQuery] bool forceSave = false) public ActionResult<TProviderResource> UpdateProvider([FromRoute] int id, [FromBody] TProviderResource providerResource, [FromQuery] bool forceSave = false)
{ {
var existingDefinition = _providerFactory.Find(providerResource.Id); // TODO: Remove fallback to Id from body in next API version bump
var existingDefinition = _providerFactory.Find(id) ?? _providerFactory.Find(providerResource.Id);
if (existingDefinition == null)
{
return NotFound();
}
var providerDefinition = GetDefinition(providerResource, existingDefinition, true, !forceSave, false); var providerDefinition = GetDefinition(providerResource, existingDefinition, true, !forceSave, false);
// Comparing via JSON string to eliminate the need for every provider implementation to implement equality checks. // Comparing via JSON string to eliminate the need for every provider implementation to implement equality checks.
@ -107,7 +114,7 @@ namespace Lidarr.Api.V1
_providerFactory.Update(providerDefinition); _providerFactory.Update(providerDefinition);
} }
return Accepted(providerResource.Id); return Accepted(existingDefinition.Id);
} }
[HttpPut("bulk")] [HttpPut("bulk")]

Loading…
Cancel
Save