Slightly modified new recipe stock fulfillment API endpoints (references #289)

This commit is contained in:
Bernd Bestel 2019-07-06 15:28:49 +02:00
parent ddef58e2a9
commit 482a520062
No known key found for this signature in database
GPG Key ID: 71BD34C0D4891300
4 changed files with 128 additions and 126 deletions

View File

@ -2,3 +2,4 @@
- Fixed that "Track date only" chores were always tracked today, regardless of the given date - Fixed that "Track date only" chores were always tracked today, regardless of the given date
- Fixed that the "week costs" were wrong after removing a meal plan entry - Fixed that the "week costs" were wrong after removing a meal plan entry
- Fixed wrong recipes costs calculation with nested recipes when the base recipe servings are > 1 (also affected the meal plan when adding such a recipe there) - Fixed wrong recipes costs calculation with nested recipes when the base recipe servings are > 1 (also affected the meal plan when adding such a recipe there)
- Improved recipes API - added new endpoints to get stock fulfillment information (thanks @Aerex)

View File

@ -41,20 +41,25 @@ class RecipesApiController extends BaseApiController
} }
} }
public function GetRecipeRequirements(\Slim\Http\Request $request, \Slim\Http\Response $response, array $args) public function GetRecipeFulfillment(\Slim\Http\Request $request, \Slim\Http\Response $response, array $args)
{
try
{
if(!isset($args['recipeId']))
{ {
try {
if(!$args['recipeId']){
return $this->ApiResponse($this->RecipesService->GetRecipesResolved()); return $this->ApiResponse($this->RecipesService->GetRecipesResolved());
} }
$recipeResolved = FindObjectInArrayByPropertyValue($this->RecipesService->GetRecipesResolved(), 'recipe_id', $args['recipeId']); $recipeResolved = FindObjectInArrayByPropertyValue($this->RecipesService->GetRecipesResolved(), 'recipe_id', $args['recipeId']);
if(!$recipeResolved) { if(!$recipeResolved)
$errorMsg ='Recipe requirments do not exist for recipe_id ' . $args['recipe_id']; {
$GenericError = $this->GenericErrorResponse($response, $errorMsg); throw new \Exception('Recipe does not exist');
return $GenericError;
} }
else
{
return $this->ApiResponse($recipeResolved); return $this->ApiResponse($recipeResolved);
} }
}
catch (\Exception $ex) catch (\Exception $ex)
{ {
return $this->GenericErrorResponse($response, $ex->getMessage()); return $this->GenericErrorResponse($response, $ex->getMessage());

View File

@ -1663,6 +1663,47 @@
} }
} }
}, },
"/recipes/{recipeId}/fulfillment": {
"get": {
"summary": "Get stock fulfillment information for the given recipe",
"tags": [
"Recipes"
],
"parameters": [
{
"in": "path",
"name": "recipeId",
"required": true,
"description": "A valid recipe id",
"schema": {
"type": "string"
}
}
],
"responses": {
"200": {
"description": "A RecipeFulfillmentResponse object",
"content": {
"application/json": {
"schema": {
"$ref": "#/components/schemas/RecipeFulfillmentResponse"
}
}
}
},
"400": {
"description": "The operation was not successful",
"content": {
"application/json": {
"schema": {
"$ref": "#/components/schemas/GenericErrorResponse"
}
}
}
}
}
}
},
"/recipes/{recipeId}/consume": { "/recipes/{recipeId}/consume": {
"post": { "post": {
"summary": "Consumes all products of the given recipe", "summary": "Consumes all products of the given recipe",
@ -1687,66 +1728,21 @@
} }
} }
}, },
"/recipes/{recipeId}/requirements": { "/recipes/fulfillment": {
"get": { "get": {
"summary": "Get requirements for recipe", "summary": "Get stock fulfillment information for all recipe",
"tags": [
"Recipes"
],
"parameters": [
{
"in": "path",
"name": "recipeId",
"required": true,
"description": "A valid recipe id",
"schema": {
"type": "string"
}
}
],
"responses": {
"200": {
"description": "A requirements recipe object",
"content": {
"application/json": {
"schema": {
"$ref": "#/components/schemas/RecipeRequirements"
}
}
}
},
"400": {
"description": "The operation was not successful",
"content": {
"application/json": {
"schema": {
"$ref": "#/components/schemas/GenericErrorResponse"
}
}
}
}
}
}
},
"/recipes/requirements": {
"get": {
"summary": "Get all requirements for recipes",
"tags": [ "tags": [
"Recipes" "Recipes"
], ],
"responses": { "responses": {
"200": { "200": {
"description": "An array of requirements recipe objects", "description": "An array of RecipeFulfillmentResponse objects",
"content": { "content": {
"application/json": { "application/json": {
"schema": { "schema": {
"type": "array", "type": "array",
"items": { "items": {
"oneOf": [ "$ref": "#/components/schemas/RecipeFulfillmentResponse"
{
"$ref": "#/components/schemas/RecipeRequirements"
}
]
} }
} }
} }
@ -2453,7 +2449,7 @@
"location_id": "4" "location_id": "4"
} }
}, },
"RecipeRequirements": { "RecipeFulfillmentResponse": {
"type": "object", "type": "object",
"properties": { "properties": {
"recipe_id": { "recipe_id": {

View File

@ -173,9 +173,9 @@ $app->group('/api', function()
if (GROCY_FEATURE_FLAG_RECIPES) if (GROCY_FEATURE_FLAG_RECIPES)
{ {
$this->post('/recipes/{recipeId}/add-not-fulfilled-products-to-shoppinglist', '\Grocy\Controllers\RecipesApiController:AddNotFulfilledProductsToShoppingList'); $this->post('/recipes/{recipeId}/add-not-fulfilled-products-to-shoppinglist', '\Grocy\Controllers\RecipesApiController:AddNotFulfilledProductsToShoppingList');
$this->get('/recipes/{recipeId}/requirements', '\Grocy\Controllers\RecipesApiController:GetRecipeRequirements'); $this->get('/recipes/{recipeId}/fulfillment', '\Grocy\Controllers\RecipesApiController:GetRecipeFulfillment');
$this->get('/recipes/requirements', '\Grocy\Controllers\RecipesApiController:GetRecipeRequirements');
$this->post('/recipes/{recipeId}/consume', '\Grocy\Controllers\RecipesApiController:ConsumeRecipe'); $this->post('/recipes/{recipeId}/consume', '\Grocy\Controllers\RecipesApiController:ConsumeRecipe');
$this->get('/recipes/fulfillment', '\Grocy\Controllers\RecipesApiController:GetRecipeFulfillment');
} }
// Chores // Chores