I am consuming a service that has the following definition:
[HttpGet]
[SwaggerOperation(nameof(GetAnimal))]
[Route("{animalId:long}", Name = nameof(GetAnimal))]
[ProducesResponseType(typeof(AnimalModel), StatusCodes.Status200OK)]
[ProducesResponseType(typeof(ErrorModel), StatusCodes.Status500InternalServerError)]
public Task<IActionResult> GetAnimal(string tenantId, long animalId)
{
try
{
// Find the actual animal.. somewhere.
return Ok(new AnimalModel());
}
catch (Exception exception)
{
return InternalServerError(new ErrorModel());
}
}
This seems to cause autorest
to generate a C# client with an object
as a return type (I guess because of the ProducesResponseType
attribute being specified twice):
public async Task<HttpOperationResponse<object>> GetAnimalWithHttpMessagesAsync(string tenantId, long animalId, [..])
Question
What is the recommended way to handle an API that return different objects?
Potential solutions
- I could fix the client code and cast the result to find the right type (not good).
- I could modify the API (if possible) so that it returns only one object composed of the
AnimalModel
and theErrorModel
(could be better).
ActionResult<T>
Consider using the new
ActionResult<T>
and remove the produces response attributeType
altogether.