Skip to content

RestAPI reference

On this page you can check the RestAPI endpoints.

Note

The API has build in csrf protection you may need to attach Cookie with value csrftoken=token to work proparly



Authentication

Create admin user

POST /api/auth/signup
Payload
authentication.UserSerializer
{
    "username": "username",
    "password": "password",
    "email": "email",
    "is_superuser": true
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
201 application/json User created successfully
400 application/json {"username":["user with this username already exists."]}
Example cURL
 curl --location 'host/api/auth/signup' --header 'X-Auth-Header: X_AUTH_HEADER' --header 'Content-Type: application/json' --data '{"username":"username","password":"password","email":"email","is_superuser":true}'

Obtain access token

POST /api/auth/token
Payload
authentication.UserSerializer
{
    "email": "email",
    "password": "password"
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"token":"token","user":{"username":"username","email":"email","is_superuser":true}}
404 application/json {"detail":"No User matches the given query."}
403 application/json {"detail": "You must use authentication header"}
Example cURL
 `curl --location 'host/api/auth/token' --header 'X-Auth-Header: X_AUTH_HEADER' --header 'Content-Type: application/json' --data '{"email":"email","password":"password"}''

Get user profile info

GET /api/auth/user/info
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
200 application/json {"username":"username","email":"email","date_joined":"date"}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'localhost:8080/api/auth/user/info' --header 'Authorization: Token token_value' 

Change user password

PUT /api/auth/user
Payload
{
    "old_password": "password",
    "new_password": "password"
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
204 application/json {}
400 application/json {"message": "Old password does not match current password"}
403 application/json {"detail": "Authentication credentials were not provided."}
Example cURL
 curl --location --request PUT 'host/api/auth/user' --header 'Authorization: Token token_value' --header 'Content-Type: application/json'  --data '{"old_password":"old_password","new_password":"new_password"}'

Update user email and username

PATCH /api/auth/user
Info

Individual fields can be updated only username or password.

Payload
authentication.UserSerializer
{
    "username": "new_username",
    "email": "new_email"
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
200 application/json {"username":"new_username","email":"new_email","is_superuser":true}
400 application/json {"email":["Enter a valid email address and password."]}
403 application/json {"detail": "Authentication credentials were not provided."}
Example cURL
 curl --location --request PATCH 'host/api/auth/user' --header 'Authorization: Token token_value'  --header 'Content-Type: application/json' --data-raw '{"username":"new_username","email":"new_email"}'

Delete user account

DELETE /api/auth/delete-account
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
204 application/json No Content
403 application/json {"detail": "Authentication credentials were not provided."}
Example cURL
 curl --location --request DELETE 'host/api/auth/delete-account' --header 'Authorization: Token token_value' 

Request password reset token for user account

POST /api/auth/password_reset
Payload
authentication.ResetPasswordRequestSerializer
{
    "email": "user_email"
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
201 application/json {"token":"token_value"}
403 application/json {"detail":"You must use authentication header"}
404 application/json {"error":"User with provided email not found"}
Example cURL
 curl --location 'host/api/auth/password_reset' --header 'Content-Type: application/json' --header 'X-Auth-Header: auth_header_value'   --data-raw '{"email":"user_email"}' 

Change user password with token

POST /api/auth/password_reset/reset

##### Parameters

name type data type description
token query (required) string Token obtained from POST /api/auth/password_reset
Payload
{
    "password": "new_password",
    "confirm_password": "new_password"
}
Responses
http code content-type response
204 application/json No Content
404 application/json {"detail":"No PasswordResetToken matches the given query."}}
Example cURL
 curl --location 'host/api/auth/password_reset/reset?token=token_value' --header 'Content-Type: application/json'  --data '{"password":"new_password","confirm_password":"new_password"}'

Recipe

Search for recipes

GET /api/recipe/home/
Parameters
name type data type description
search query (optional) string Part or fulll name of the recipe.Recipe object
page query (optional) int Page number if there a mutilple pages result
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/?name=name&page=1' --header 'X-Auth-Header: X_AUTH_HEADER

Get favorite recipes

GET /api/recipe/home/favorites/
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
404 application/json {"detail":"No Recipe matches the given query."}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/favorites/' --header 'X-Auth-Header: X_AUTH_HEADER
GET /api/recipe/trending
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Recipe objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'localhost:8080/api/recipe/trending' --header 'X-Auth-Header: X_AUTH_HEADER

Search for recipes preview

GET /api/recipe/home/preview/
Parameters
name type data type description
search query (optional) string Part or fulll name of the recipe.Recipe object
page query (optional) int Page number if there a mutilple pages result
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.RecipePreviewSerializer obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/preview/?name=name&page=1' --header 'X-Auth-Header: X_AUTH_HEADER

Update favorite status

PATCH /api/recipe/int:pk/favorite
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be favorited or unfavorited
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
201 application/json "Success favorite recipe"
201 application/json "Success unfavorite recipe"
403 application/json `{"detail":"You must use authentication header"}
404 application/json Not Found
Example cURL
 curl --location --request PATCH 'host/api/recipe/1/favorite' --header 'X-Auth-Header: X_AUTH_HEADER'

Get recipe by pk

GET /api/recipe/int:pk/
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be updated
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {recipe.Recipe object}
403 application/json {"detail":"You must use authentication header"}
404 application/json {"detail":"No Recipe matches the given query."}
Example cURL
 curl --location --request GET 'host/api/recipe/1/' --header 'X-Auth-Header: X_AUTH_HEADER

Create recipe

POST /api/recipe/
Payload
recipe.Recipe object
{
    "image": file,
    "name": string,
    "serves": int,
    "description": string,
    "difficulty": string (DIFFICULTY_CHOICES),
    "chef": string
    "video": file (optional),
    "category": <int:pk> (optional),
    "tag": <int:pk> (optional), 
    "prep_time": int,
    "cook_time": int
}
Dificulty choices (DIFFICULTY_CHOICES)
recipe.Recipe.DIFFICULTY_CHOICES (use only the key in the request)
    ('Easy', 'Easy'),
    ('Intermediate', 'Intermediate'),
    ('Advanced', 'Advanced'),
    ('Expert', 'Expert'),
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type multipart/form-data Recipe object Recipe multipart/form-data object
Responses
http code content-type response
201 application/json {recipe.Recipe object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/' --header 'Authorization: Token token_value' --form  'image=@"/path/image.jpg"' --form 'name="Recipe name"' --form 'servings="5"' --form 'category="1"' --form 'tag="1"' --form 'prep_time="20"' --form 'video=@"/path/video.mp4"' --form 'description="This is cool recipe"' --form 'cook_time="45"'

Update recipe main info (without ingredients and steps)

PUT /api/recipe/int:pk
Payload
recipe.Recipe object
{
    "image": file,
    "name": string,
    "serves": int,
    "description": string,
    "difficulty": string (DIFFICULTY_CHOICES),
    "chef": string
    "video": file (optional),
    "category": <int:pk> (optional),
    "tag": <int:pk> (optional), 
    "prep_time": int,
    "cook_time": int,
    "clear_video": boolean (optional if you want to delete already set video)
}
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be updated
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type multipart/form-data Recipe object Recipe multipart/form-data object
Responses
http code content-type response
200 application/json {recipe.Recipe object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location --request PUT 'host/api/recipe/1' --header 'Authorization: Token token_value' --form  'image=@"/path/image.jpg"' --form 'name="Recipe name"' --form 'servings="5"' --form 'category="1"' --form 'tag="1"' --form 'prep_time="20"' --form 'video=@"/path/video.mp4"' --form 'description="This is cool recipe"' --form 'cook_time="45"'

Delete recipes

DELETE /api/recipe/pk:int/
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be deleted
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
204 application/json
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location --request DELETE 'host/api/recipe/<int:pk>/' --header 'Authorization: Token token_value' 

Scrape recipes

POST /api/recipe/scrape
Info

Valid OpenAI API Key is nedded for this endpoint

Payload
recipe.RecipeLink object
{
    "url": file
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
200 application/json {recipe.Recipe object}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
curl --location 'host/api/recipe/scrape' --header 'Authorization: Token token_value'  --data '{"url":"http://...."}'

Generate recipes

POST /api/recipe/generate
Info

Valid OpenAI API Key is nedded for this endpoint

Payload
GenerateRecipeSerializer list of strings
{
    "ingredients": []
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
200 application/json [GenerateRecipeResultSerializer objects]
204 application/json {Empty response if there a openai empty response}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
curl --location 'host/api/recipe/generate' --header 'Authorization: Token token_value' --header 'Content-Type: application/json' --data '{"ingredients":["tomato","onion","cheese","pasta","milk","red peparz"]}'

Category

Get all categories

GET /api/recipe/category
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Category objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/category' --header 'X-Auth-Header: X_AUTH_HEADER'

Get all categories recipes

GET /api/recipe/category/int:pk/recipes
Parameters
name type data type description
<int:pk> path (required) int Category primary key
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Recipe objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/category/1/recipes' --header 'X-Auth-Header: X_AUTH_HEADER'

Create category

POST /api/recipe/category/add
Payload
recipe.Category object
{
    "name": string
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json {recipe.Category object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/category/add' --header 'Authorization: Token token_value' --data '{"name":"Greek"}'

Update category

PUT /api/recipe/category/int:pk
Payload
recipe.Category object
{
    "name": string,

}
Parameters
name type data type description
<int:pk> path (required) int Category primary key
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
200 application/json {recipe.Recipe object}
401 application/json {"detail":"Authentication credentials were not provided."}
404 application/json {"detail":"No Category matches the given query."}
Example cURL
 curl --location --request PUT 'host/api/recipe/category/6' --header 'Authorization: Token token_value'  --header 'Content-Type: application/json'  --data '{"name":"Italiano"}'

Tag

Get all tags

GET /api/recipe/tags
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Tag objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/tags' --header 'X-Auth-Header: X_AUTH_HEADER'

Get all recipes from tag

GET /api/recipe/tag/int:pk/recipes
Parameters
name type data type description
<int:pk> path (required) int Tag primary key
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/tag/<int:pk>/recipes' --header 'X-Auth-Header: X_AUTH_HEADER'

Create tag

POST /api/recipe/tag/add
Payload
recipe.Tag object
{
    "name": string
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json {recipe.Category object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/tag/add' --header 'Authorization: Token token_value' --data '{"name":"Summer vibes"}'

Update tag

PUT /api/recipe/tag/int:pk
Payload
recipe.Category object
{
    "name": string,

}
Parameters
name type data type description
<int:pk> path (required) int Tag primary key
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
200 application/json {recipe.Tag object}
401 application/json {"detail":"Authentication credentials were not provided."}
404 application/json {"detail":"No Category matches the given query."}
Example cURL
 curl --location --request PUT 'host/api/recipe/tag/1' --header 'Authorization: Token token_value'  --header 'Content-Type: application/json'  --data '{"name":"Summer Vibes"}'

Ingredients

POST /api/recipe/int:pk/ingredients
Info

Override already existing ingredients for the recipe

Payload
recipe.Igredient object list
[
    {
        "name": "string,
        "quantity": string,
        "metric": "string
    },
    {
        "name": "string,
        "quantity": string,
        "metric": "string
    },
....
]
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to which to link the ingredients
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json [{recipe.Ingrediant object}]
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/ingredients' --header 'Authorization: Token token_value' --data '[{"name":"Kasher salt","quantity":"1/5","metric":"tbsp","recipe":24}]'

Steps

POST /api/recipe/int:pk/steps
Info

Override already existing steps for the recipe

Payload
recipe.Step object list
[
    {
        "text": string
    },
    {
        "text": string
    },
....
]
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to which to link the steps
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json [{recipe.Step object}]
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/ingredients' --header 'Authorization: Token token_value' --data '[{"text":"Heat the oven","recipe":1}]'


Authentication

Create admin user

POST /api/auth/signup
Payload
authentication.UserSerializer
{
    "username": "username",
    "password": "password",
    "email": "email",
    "is_superuser": true
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
201 application/json User created successfully
400 application/json {"username":["user with this username already exists."]}
Example cURL
 curl --location 'host/api/auth/signup' --header 'X-Auth-Header: X_AUTH_HEADER' --header 'Content-Type: application/json' --data '{"username":"username","password":"password","email":"email","is_superuser":true}'

Obtain access token

POST /api/auth/token
Payload
authentication.UserSerializer
{
    "email": "email",
    "password": "password"
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"token":"token","user":{"username":"username","email":"email","is_superuser":true}}
404 application/json {"detail":"No User matches the given query."}
403 application/json {"detail": "You must use authentication header"}
Example cURL
 `curl --location 'host/api/auth/token' --header 'X-Auth-Header: X_AUTH_HEADER' --header 'Content-Type: application/json' --data '{"email":"email","password":"password"}''

Get user profile info

GET /api/auth/user/info
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
200 application/json {"username":"username","email":"email","date_joined":"date"}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'localhost:8080/api/auth/user/info' --header 'Authorization: Token token_value' 

Change user password

PUT /api/auth/user
Payload
{
    "old_password": "password",
    "new_password": "password"
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
204 application/json {}
400 application/json {"message": "Old password does not match current password"}
403 application/json {"detail": "Authentication credentials were not provided."}
Example cURL
 curl --location --request PUT 'host/api/auth/user' --header 'Authorization: Token token_value' --header 'Content-Type: application/json'  --data '{"old_password":"old_password","new_password":"new_password"}'

Update user email and username

PATCH /api/auth/user
Info

Individual fields can be updated only username or password.

Payload
authentication.UserSerializer
{
    "username": "new_username",
    "email": "new_email"
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
200 application/json {"username":"new_username","email":"new_email","is_superuser":true}
400 application/json {"email":["Enter a valid email address and password."]}
403 application/json {"detail": "Authentication credentials were not provided."}
Example cURL
 curl --location --request PATCH 'host/api/auth/user' --header 'Authorization: Token token_value'  --header 'Content-Type: application/json' --data-raw '{"username":"new_username","email":"new_email"}'

Delete user account

DELETE /api/auth/delete-account
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
204 application/json No Content
403 application/json {"detail": "Authentication credentials were not provided."}
Example cURL
 curl --location --request DELETE 'host/api/auth/delete-account' --header 'Authorization: Token token_value' 

Request password reset token for user account

POST /api/auth/password_reset
Payload
authentication.ResetPasswordRequestSerializer
{
    "email": "user_email"
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
201 application/json {"token":"token_value"}
403 application/json {"detail":"You must use authentication header"}
404 application/json {"error":"User with provided email not found"}
Example cURL
 curl --location 'host/api/auth/password_reset' --header 'Content-Type: application/json' --header 'X-Auth-Header: auth_header_value'   --data-raw '{"email":"user_email"}' 

Change user password with token

POST /api/auth/password_reset/reset

##### Parameters

name type data type description
token query (required) string Token obtained from POST /api/auth/password_reset
Payload
{
    "password": "new_password",
    "confirm_password": "new_password"
}
Responses
http code content-type response
204 application/json No Content
404 application/json {"detail":"No PasswordResetToken matches the given query."}}
Example cURL
 curl --location 'host/api/auth/password_reset/reset?token=token_value' --header 'Content-Type: application/json'  --data '{"password":"new_password","confirm_password":"new_password"}'

Recipe

Search for recipes

GET /api/recipe/home/
Parameters
name type data type description
search query (optional) string Part or fulll name of the recipe.Recipe object
page query (optional) int Page number if there a mutilple pages result
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/?name=name&page=1' --header 'X-Auth-Header: X_AUTH_HEADER

Get favorite recipes

GET /api/recipe/home/favorites/
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
404 application/json {"detail":"No Recipe matches the given query."}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/favorites/' --header 'X-Auth-Header: X_AUTH_HEADER
GET /api/recipe/trending
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Recipe objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'localhost:8080/api/recipe/trending' --header 'X-Auth-Header: X_AUTH_HEADER

Search for recipes preview

GET /api/recipe/home/preview/
Parameters
name type data type description
search query (optional) string Part or fulll name of the recipe.Recipe object
page query (optional) int Page number if there a mutilple pages result
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.RecipePreviewSerializer obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/preview/?name=name&page=1' --header 'X-Auth-Header: X_AUTH_HEADER

Update favorite status

PATCH /api/recipe/int:pk/favorite
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be favorited or unfavorited
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
201 application/json "Success favorite recipe"
201 application/json "Success unfavorite recipe"
403 application/json `{"detail":"You must use authentication header"}
404 application/json Not Found
Example cURL
 curl --location --request PATCH 'host/api/recipe/1/favorite' --header 'X-Auth-Header: X_AUTH_HEADER'

Get recipe by pk

GET /api/recipe/int:pk/
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be updated
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {recipe.Recipe object}
403 application/json {"detail":"You must use authentication header"}
404 application/json {"detail":"No Recipe matches the given query."}
Example cURL
 curl --location --request GET 'host/api/recipe/1/' --header 'X-Auth-Header: X_AUTH_HEADER

Create recipe

POST /api/recipe/
Payload
recipe.Recipe object
{
    "image": file,
    "name": string,
    "serves": int,
    "description": string,
    "difficulty": string (DIFFICULTY_CHOICES),
    "chef": string
    "video": file (optional),
    "category": <int:pk> (optional),
    "tag": <int:pk> (optional), 
    "prep_time": int,
    "cook_time": int
}
Dificulty choices (DIFFICULTY_CHOICES)
recipe.Recipe.DIFFICULTY_CHOICES (use only the key in the request)
    ('Easy', 'Easy'),
    ('Intermediate', 'Intermediate'),
    ('Advanced', 'Advanced'),
    ('Expert', 'Expert'),
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type multipart/form-data Recipe object Recipe multipart/form-data object
Responses
http code content-type response
201 application/json {recipe.Recipe object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/' --header 'Authorization: Token token_value' --form  'image=@"/path/image.jpg"' --form 'name="Recipe name"' --form 'servings="5"' --form 'category="1"' --form 'tag="1"' --form 'prep_time="20"' --form 'video=@"/path/video.mp4"' --form 'description="This is cool recipe"' --form 'cook_time="45"'

Update recipe main info (without ingredients and steps)

PUT /api/recipe/int:pk
Payload
recipe.Recipe object
{
    "image": file,
    "name": string,
    "serves": int,
    "description": string,
    "difficulty": string (DIFFICULTY_CHOICES),
    "chef": string
    "video": file (optional),
    "category": <int:pk> (optional),
    "tag": <int:pk> (optional), 
    "prep_time": int,
    "cook_time": int,
    "clear_video": boolean (optional if you want to delete already set video)
}
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be updated
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type multipart/form-data Recipe object Recipe multipart/form-data object
Responses
http code content-type response
200 application/json {recipe.Recipe object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location --request PUT 'host/api/recipe/1' --header 'Authorization: Token token_value' --form  'image=@"/path/image.jpg"' --form 'name="Recipe name"' --form 'servings="5"' --form 'category="1"' --form 'tag="1"' --form 'prep_time="20"' --form 'video=@"/path/video.mp4"' --form 'description="This is cool recipe"' --form 'cook_time="45"'

Delete recipes

DELETE /api/recipe/pk:int/
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be deleted
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
204 application/json
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location --request DELETE 'host/api/recipe/<int:pk>/' --header 'Authorization: Token token_value' 

Scrape recipes

POST /api/recipe/scrape
Info

Valid OpenAI API Key is nedded for this endpoint

Payload
recipe.RecipeLink object
{
    "url": file
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
200 application/json {recipe.Recipe object}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
curl --location 'host/api/recipe/scrape' --header 'Authorization: Token token_value'  --data '{"url":"http://...."}'

Category

Get all categories

GET /api/recipe/category
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Category objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/category' --header 'X-Auth-Header: X_AUTH_HEADER'

Get all categories recipes

GET /api/recipe/category/int:pk/recipes
Parameters
name type data type description
<int:pk> path (required) int Category primary key
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Recipe objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/category/1/recipes' --header 'X-Auth-Header: X_AUTH_HEADER'

Create category

POST /api/recipe/category/add
Payload
recipe.Category object
{
    "name": string
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json {recipe.Category object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/category/add' --header 'Authorization: Token token_value' --data '{"name":"Greek"}'

Update category

PUT /api/recipe/category/int:pk
Payload
recipe.Category object
{
    "name": string,

}
Parameters
name type data type description
<int:pk> path (required) int Category primary key
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
200 application/json {recipe.Recipe object}
401 application/json {"detail":"Authentication credentials were not provided."}
404 application/json {"detail":"No Category matches the given query."}
Example cURL
 curl --location --request PUT 'host/api/recipe/category/6' --header 'Authorization: Token token_value'  --header 'Content-Type: application/json'  --data '{"name":"Italiano"}'

Tag

Get all tags

GET /api/recipe/tags
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Tag objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/tags' --header 'X-Auth-Header: X_AUTH_HEADER'

Get all recipes from tag

GET /api/recipe/tag/int:pk/recipes
Parameters
name type data type description
<int:pk> path (required) int Tag primary key
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/tag/<int:pk>/recipes' --header 'X-Auth-Header: X_AUTH_HEADER'

Create tag

POST /api/recipe/tag/add
Payload
recipe.Tag object
{
    "name": string
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json {recipe.Category object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/tag/add' --header 'Authorization: Token token_value' --data '{"name":"Summer vibes"}'

Update tag

PUT /api/recipe/tag/int:pk
Payload
recipe.Category object
{
    "name": string,

}
Parameters
name type data type description
<int:pk> path (required) int Tag primary key
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
200 application/json {recipe.Tag object}
401 application/json {"detail":"Authentication credentials were not provided."}
404 application/json {"detail":"No Category matches the given query."}
Example cURL
 curl --location --request PUT 'host/api/recipe/tag/1' --header 'Authorization: Token token_value'  --header 'Content-Type: application/json'  --data '{"name":"Summer Vibes"}'

Ingredients

POST /api/recipe/int:pk/ingredients
Info

Override already existing ingredients for the recipe

Payload
recipe.Igredient object list
[
    {
        "name": "string,
        "quantity": string,
        "metric": "string
    },
    {
        "name": "string,
        "quantity": string,
        "metric": "string
    },
....
]
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to which to link the ingredients
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json [{recipe.Ingrediant object}]
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/ingredients' --header 'Authorization: Token token_value' --data '[{"name":"Kasher salt","quantity":"1/5","metric":"tbsp","recipe":24}]'

Steps

POST /api/recipe/int:pk/steps
Info

Override already existing steps for the recipe

Payload
recipe.Step object list
[
    {
        "text": string
    },
    {
        "text": string
    },
....
]
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to which to link the steps
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json [{recipe.Step object}]
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/ingredients' --header 'Authorization: Token token_value' --data '[{"text":"Heat the oven","recipe":1}]'


Authentication

Create admin user

POST /api/auth/signup
Payload
authentication.UserSerializer
{
    "username": "username",
    "password": "password",
    "email": "email",
    "is_superuser": true
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
201 application/json User created successfully
400 application/json {"username":["user with this username already exists."]}
Example cURL
 curl --location 'host/api/auth/signup' --header 'X-Auth-Header: X_AUTH_HEADER' --header 'Content-Type: application/json' --data '{"username":"username","password":"password","email":"email","is_superuser":true}'

Obtain access token

POST /api/auth/token
Payload
authentication.UserSerializer
{
    "email": "email",
    "password": "password"
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"token":"token","user":{"username":"username","email":"email","is_superuser":true}}
404 application/json {"detail":"No User matches the given query."}
403 application/json {"detail": "You must use authentication header"}
Example cURL
 `curl --location 'host/api/auth/token' --header 'X-Auth-Header: X_AUTH_HEADER' --header 'Content-Type: application/json' --data '{"email":"email","password":"password"}''

Get user profile info

GET /api/auth/user/info
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
200 application/json {"username":"username","email":"email","date_joined":"date"}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'localhost:8080/api/auth/user/info' --header 'Authorization: Token token_value' 

Change user password

PUT /api/auth/user
Payload
{
    "old_password": "password",
    "new_password": "password"
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
204 application/json {}
400 application/json {"message": "Old password does not match current password"}
403 application/json {"detail": "Authentication credentials were not provided."}
Example cURL
 curl --location --request PUT 'host/api/auth/user' --header 'Authorization: Token token_value' --header 'Content-Type: application/json'  --data '{"old_password":"old_password","new_password":"new_password"}'

Update user email and username

PATCH /api/auth/user
Info

Individual fields can be updated only username or password.

Payload
authentication.UserSerializer
{
    "username": "new_username",
    "email": "new_email"
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
200 application/json {"username":"new_username","email":"new_email","is_superuser":true}
400 application/json {"email":["Enter a valid email address and password."]}
403 application/json {"detail": "Authentication credentials were not provided."}
Example cURL
 curl --location --request PATCH 'host/api/auth/user' --header 'Authorization: Token token_value'  --header 'Content-Type: application/json' --data-raw '{"username":"new_username","email":"new_email"}'

Delete user account

DELETE /api/auth/delete-account
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
204 application/json No Content
403 application/json {"detail": "Authentication credentials were not provided."}
Example cURL
 curl --location --request DELETE 'host/api/auth/delete-account' --header 'Authorization: Token token_value' 

Request password reset token for user account

POST /api/auth/password_reset
Payload
authentication.ResetPasswordRequestSerializer
{
    "email": "user_email"
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
201 application/json {"token":"token_value"}
403 application/json {"detail":"You must use authentication header"}
404 application/json {"error":"User with provided email not found"}
Example cURL
 curl --location 'host/api/auth/password_reset' --header 'Content-Type: application/json' --header 'X-Auth-Header: auth_header_value'   --data-raw '{"email":"user_email"}' 

Change user password with token

POST /api/auth/password_reset/reset

##### Parameters

name type data type description
token query (required) string Token obtained from POST /api/auth/password_reset
Payload
{
    "password": "new_password",
    "confirm_password": "new_password"
}
Responses
http code content-type response
204 application/json No Content
404 application/json {"detail":"No PasswordResetToken matches the given query."}}
Example cURL
 curl --location 'host/api/auth/password_reset/reset?token=token_value' --header 'Content-Type: application/json'  --data '{"password":"new_password","confirm_password":"new_password"}'

Recipe

Search for recipes

GET /api/recipe/home/
Parameters
name type data type description
search query (optional) string Part or fulll name of the recipe.Recipe object
page query (optional) int Page number if there a mutilple pages result
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/?name=name&page=1' --header 'X-Auth-Header: X_AUTH_HEADER

Get favorite recipes

GET /api/recipe/home/favorites/
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
404 application/json {"detail":"No Recipe matches the given query."}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/favorites/' --header 'X-Auth-Header: X_AUTH_HEADER
GET /api/recipe/trending
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Recipe objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'localhost:8080/api/recipe/trending' --header 'X-Auth-Header: X_AUTH_HEADER

Search for recipes preview

GET /api/recipe/home/preview/
Parameters
name type data type description
search query (optional) string Part or fulll name of the recipe.Recipe object
page query (optional) int Page number if there a mutilple pages result
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.RecipePreviewSerializer obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/preview/?name=name&page=1' --header 'X-Auth-Header: X_AUTH_HEADER

Update favorite status

PATCH /api/recipe/int:pk/favorite
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be favorited or unfavorited
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
201 application/json "Success favorite recipe"
201 application/json "Success unfavorite recipe"
403 application/json `{"detail":"You must use authentication header"}
404 application/json Not Found
Example cURL
 curl --location --request PATCH 'host/api/recipe/1/favorite' --header 'X-Auth-Header: X_AUTH_HEADER'

Get recipe by pk

GET /api/recipe/int:pk/
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be updated
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {recipe.Recipe object}
403 application/json {"detail":"You must use authentication header"}
404 application/json {"detail":"No Recipe matches the given query."}
Example cURL
 curl --location --request GET 'host/api/recipe/1/' --header 'X-Auth-Header: X_AUTH_HEADER

Create recipe

POST /api/recipe/
Payload
recipe.Recipe object
{
    "image": file,
    "name": string,
    "serves": int,
    "description": string,
    "difficulty": string (DIFFICULTY_CHOICES),
    "chef": string
    "video": file (optional),
    "category": <int:pk> (optional),
    "tag": <int:pk> (optional), 
    "prep_time": int,
    "cook_time": int
}
Dificulty choices (DIFFICULTY_CHOICES)
recipe.Recipe.DIFFICULTY_CHOICES (use only the key in the request)
    ('Easy', 'Easy'),
    ('Intermediate', 'Intermediate'),
    ('Advanced', 'Advanced'),
    ('Expert', 'Expert'),
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type multipart/form-data Recipe object Recipe multipart/form-data object
Responses
http code content-type response
201 application/json {recipe.Recipe object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/' --header 'Authorization: Token token_value' --form  'image=@"/path/image.jpg"' --form 'name="Recipe name"' --form 'servings="5"' --form 'category="1"' --form 'tag="1"' --form 'prep_time="20"' --form 'video=@"/path/video.mp4"' --form 'description="This is cool recipe"' --form 'cook_time="45"'

Update recipe main info (without ingredients and steps)

PUT /api/recipe/int:pk
Payload
recipe.Recipe object
{
    "image": file,
    "name": string,
    "serves": int,
    "description": string,
    "difficulty": string (DIFFICULTY_CHOICES),
    "chef": string
    "video": file (optional),
    "category": <int:pk> (optional),
    "tag": <int:pk> (optional), 
    "prep_time": int,
    "cook_time": int,
    "clear_video": boolean (optional if you want to delete already set video)
}
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be updated
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type multipart/form-data Recipe object Recipe multipart/form-data object
Responses
http code content-type response
200 application/json {recipe.Recipe object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location --request PUT 'host/api/recipe/1' --header 'Authorization: Token token_value' --form  'image=@"/path/image.jpg"' --form 'name="Recipe name"' --form 'servings="5"' --form 'category="1"' --form 'tag="1"' --form 'prep_time="20"' --form 'video=@"/path/video.mp4"' --form 'description="This is cool recipe"' --form 'cook_time="45"'

Delete recipes

DELETE /api/recipe/pk:int/
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be deleted
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Responses
http code content-type response
204 application/json
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location --request DELETE 'host/api/recipe/<int:pk>/' --header 'Authorization: Token token_value' 

Category

Get all categories

GET /api/recipe/category
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Category objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/category' --header 'X-Auth-Header: X_AUTH_HEADER'

Get all categories recipes

GET /api/recipe/category/int:pk/recipes
Parameters
name type data type description
<int:pk> path (required) int Category primary key
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Recipe objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/category/1/recipes' --header 'X-Auth-Header: X_AUTH_HEADER'

Create category

POST /api/recipe/category/add
Payload
recipe.Category object
{
    "name": string
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json {recipe.Category object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/category/add' --header 'Authorization: Token token_value' --data '{"name":"Greek"}'

Update category

PUT /api/recipe/category/int:pk
Payload
recipe.Category object
{
    "name": string,

}
Parameters
name type data type description
<int:pk> path (required) int Category primary key
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
200 application/json {recipe.Recipe object}
401 application/json {"detail":"Authentication credentials were not provided."}
404 application/json {"detail":"No Category matches the given query."}
Example cURL
 curl --location --request PUT 'host/api/recipe/category/6' --header 'Authorization: Token token_value'  --header 'Content-Type: application/json'  --data '{"name":"Italiano"}'

Tag

Get all tags

GET /api/recipe/tags
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Tag objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/tags' --header 'X-Auth-Header: X_AUTH_HEADER'

Get all recipes from tag

GET /api/recipe/tag/int:pk/recipes
Parameters
name type data type description
<int:pk> path (required) int Tag primary key
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/tag/<int:pk>/recipes' --header 'X-Auth-Header: X_AUTH_HEADER'

Create tag

POST /api/recipe/tag/add
Payload
recipe.Tag object
{
    "name": string
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json {recipe.Category object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/tag/add' --header 'Authorization: Token token_value' --data '{"name":"Summer vibes"}'

Update tag

PUT /api/recipe/tag/int:pk
Payload
recipe.Category object
{
    "name": string,

}
Parameters
name type data type description
<int:pk> path (required) int Tag primary key
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
200 application/json {recipe.Tag object}
401 application/json {"detail":"Authentication credentials were not provided."}
404 application/json {"detail":"No Category matches the given query."}
Example cURL
 curl --location --request PUT 'host/api/recipe/tag/1' --header 'Authorization: Token token_value'  --header 'Content-Type: application/json'  --data '{"name":"Summer Vibes"}'

Ingredients

POST /api/recipe/int:pk/ingredients
Info

Override already existing ingredients for the recipe

Payload
recipe.Igredient object list
[
    {
        "name": "string,
        "quantity": string,
        "metric": "string
    },
    {
        "name": "string,
        "quantity": string,
        "metric": "string
    },
....
]
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to which to link the ingredients
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json [{recipe.Ingrediant object}]
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/ingredients' --header 'Authorization: Token token_value' --data '[{"name":"Kasher salt","quantity":"1/5","metric":"tbsp","recipe":24}]'

Steps

POST /api/recipe/int:pk/steps
Info

Override already existing steps for the recipe

Payload
recipe.Step object list
[
    {
        "text": string
    },
    {
        "text": string
    },
....
]
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to which to link the steps
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json [{recipe.Step object}]
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/ingredients' --header 'Authorization: Token token_value' --data '[{"text":"Heat the oven","recipe":1}]'


Authentication

Create admin user

POST /api/auth/signup
Payload
authentication.UserSerializer
{
    "username": "username",
    "password": "password",
    "is_superuser": true
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
201 application/json User created successfully
400 application/json {"username":["user with this username already exists."]}
Example cURL
 curl --location 'host/api/auth/signup' --header 'X-Auth-Header: X_AUTH_HEADER' --header 'Content-Type: application/json' --data '{"username":"username","password":"password","is_superuser":true}'

Obtain access token

POST /api/auth/token
Payload
authentication.UserSerializer
{
    "username": "username",
    "password": "password"
}
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"token":"token","user":{"username":"username","is_superuser":true}}
404 application/json {"detail":"No User matches the given query."}
403 application/json {"detail": "You must use authentication header"}
Example cURL
 `curl --location 'host/api/auth/token' --header 'X-Auth-Header: X_AUTH_HEADER' --header 'Content-Type: application/json' --data '{"username":"username","password":"password"}''

Recipe

Search for recipes

GET /api/recipe/home/
Parameters
name type data type description
search query (optional) string Part or fulll name of the recipe.Recipe object
page query (optional) int Page number if there a mutilple pages result
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/?name=name&page=1' --header 'X-Auth-Header: X_AUTH_HEADER

Get favorite recipes

GET /api/recipe/home/favorites/
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
404 application/json {"detail":"No Recipe matches the given query."}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'http://host:port/api/recipe/home/favorites/' --header 'X-Auth-Header: X_AUTH_HEADER
GET /api/recipe/trending
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Recipe objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'localhost:8080/api/recipe/trending' --header 'X-Auth-Header: X_AUTH_HEADER

Update favorite status

PATCH /api/recipe/int:pk/favorite
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be favorited or unfavorited
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Responses
http code content-type response
201 application/json "Success favorite recipe"
201 application/json "Success unfavorite recipe"
403 application/json `{"detail":"You must use authentication header"}
404 application/json Not Found
Example cURL
 curl --location --request PATCH 'host/api/recipe/1/favorite' --header 'X-Auth-Header: X_AUTH_HEADER'

Create recipe

POST /api/recipe/
Payload
recipe.Recipe object
{
    "image": file,
    "name": string,
    "serves": int,
    "video": file (optional),
    "category": <int:pk>,
    "tag": <int:pk>,
    "prep_time": int,
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Content-Type multipart/form-data Recipe object Recipe multipart/form-data object
Responses
http code content-type response
201 application/json {recipe.Recipe object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'localhost:8080/api/recipe/'  --header 'Authorization: Token d8916a5f6cf16d2c6a87bc7461bc4680245609f0' --form 'image=@"/path/image.jpg"' --form 'name="Test recipe creation"' --form 'serves="5"' --form 'category="1"' --form 'tag=1' --form 'prep_time="45"'

Update recipe main info (without ingredients and steps)

PUT /api/recipe/int:pk
Payload
recipe.Recipe object
{
    "image": file,
    "name": string,
    "serves": int,
    "video": file (optional),
    "category": <int:pk>,
    "tag": <int:pk>,
    "prep_time": int,
}
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be updated
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Content-Type multipart/form-data Recipe object Recipe multipart/form-data object
Responses
http code content-type response
200 application/json {recipe.Recipe object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location --request PUT 'host/api/recipe/1' --header 'Authorization: Token d8916a5f6cf16d2c6a87bc7461bc4680245609f0' --form 'image=@"/path/image.jpg"' --form 'name="Update name"' --form 'serves="4"' --form 'category="1"' --form 'tag="1"' --form 'prep_time="21"'

Delete recipes

DELETE /api/recipe/pk:int/
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to be deleted
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Responses
http code content-type response
204 application/json
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location --request DELETE 'host/api/recipe/<int:pk>/' --header 'Authorization: Token d8916a5f6cf16d2c6a87bc7461bc4680245609f0' 

Category

Get all categories

GET /api/recipe/category
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Category objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/category' --header 'X-Auth-Header: X_AUTH_HEADER'

Get all categories recipes

GET /api/recipe/category/int:pk/recipes
Parameters
name type data type description
<int:pk> path (required) int Category primary key
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Recipe objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/category/1/recipes' --header 'X-Auth-Header: X_AUTH_HEADER'

Create category

POST /api/recipe/category/add
Payload
recipe.Category object
{
    "name": string
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json {recipe.Category object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/category/add' --header 'Authorization: token 443c104be8c6daeeaf86df634e69b97668b99900' --data '{"name":"Greek"}'

Update category

PUT /api/recipe/category/int:pk
Payload
recipe.Category object
{
    "name": string,

}
Parameters
name type data type description
<int:pk> path (required) int Category primary key
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
200 application/json {recipe.Recipe object}
401 application/json {"detail":"Authentication credentials were not provided."}
404 application/json {"detail":"No Category matches the given query."}
Example cURL
 curl --location --request PUT 'host/api/recipe/category/6' --header 'Authorization: token 443c104be8c6daeeaf86df634e69b97668b99900'  --header 'Content-Type: application/json'  --data '{"name":"Italiano"}'

Tag

Get all tags

GET /api/recipe/tags
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json [recipe.Tag objects list]
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/tags' --header 'X-Auth-Header: X_AUTH_HEADER'

Get all recipes from tag

GET /api/recipe/tag/int:pk/recipes
Parameters
name type data type description
<int:pk> path (required) int Tag primary key
Headers
name type data type description
X-Auth-Header required UUID Header used for authentication with the API
Responses
http code content-type response
200 application/json {"count":int,"next":string,"previous":string,"results":[recipe.Recipe obj list]}
403 application/json {"detail":"You must use authentication header"}
Example cURL
 curl --location 'host/api/recipe/tag/<int:pk>/recipes' --header 'X-Auth-Header: X_AUTH_HEADER'

Create tag

POST /api/recipe/tag/add
Payload
recipe.Tag object
{
    "name": string
}
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json {recipe.Category object}
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/tag/add' --header 'Authorization: token 443c104be8c6daeeaf86df634e69b97668b99900' --data '{"name":"Summer vibes"}'

Update tag

PUT /api/recipe/tag/int:pk
Payload
recipe.Category object
{
    "name": string,

}
Parameters
name type data type description
<int:pk> path (required) int Tag primary key
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
200 application/json {recipe.Tag object}
401 application/json {"detail":"Authentication credentials were not provided."}
404 application/json {"detail":"No Category matches the given query."}
Example cURL
 curl --location --request PUT 'host/api/recipe/tag/1' --header 'Authorization: token 443c104be8c6daeeaf86df634e69b97668b99900'  --header 'Content-Type: application/json'  --data '{"name":"Summer Vibes"}'

Ingredients

POST /api/recipe/int:pk/ingredients
Info

Override already existing ingredients for the recipe

Payload
recipe.Igredient object list
[
    {
        "name": "string,
        "quantity": string,
        "metric": "string
    },
    {
        "name": "string,
        "quantity": string,
        "metric": "string
    },
....
]
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to which to link the ingredients
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json [{recipe.Ingrediant object}]
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/ingredients' --header 'Authorization: token 443c104be8c6daeeaf86df634e69b97668b99900' --data '[{"name":"Kasher salt","quantity":"1/5","metric":"tbsp","recipe":24}]'

Steps

POST /api/recipe/int:pk/steps
Info

Override already existing steps for the recipe

Payload
recipe.Step object list
[
    {
        "text": string
    },
    {
        "text": string
    },
....
]
Parameters
name type data type description
<int:pk> path (required) int Recipe primary key to which to link the steps
Headers
name type data type description
Authorization required Access Token Token obtained from login endpoint example "token 443c104be8c6daeeaf86df634e69b97668b99900"
Content-Type application/json `Applicaton Json content header
Responses
http code content-type response
201 application/json [{recipe.Step object}]
400 application/json {"tag":["Incorrect type. message"]}
401 application/json {"detail":"Authentication credentials were not provided."}
Example cURL
 curl --location 'host/api/recipe/ingredients' --header 'Authorization: token 443c104be8c6daeeaf86df634e69b97668b99900' --data '[{"text":"Heat the oven","recipe":1}]'