API Staus

ENABLED

General Info

This is a REST API which can be used to interact with the Tamari application.

Number of endpoints is unknown.

X-App-Name and X-App-Key headers are not required, as configured in config.py.

About

GET/api/infoView Version
Response Example

Status: 200

{
    "api_enabled": true,
    "headers_required": false,
    "app_version": 1.1
}

Account

POST/api/user/authenticateLogin
Request Exampleapplication/json
{
    "email": "[email protected]",
    "password": "1234"
}
Response Exampleapplication/json

Status: 200

{
    "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJmcmVzaCI6ZmFsc2UsImlhdCI6MTczMTc3ODM1MSwianRpIjoiZDRlYzdkZmItZTc5Yi00ZTYzLTg1NmEtMTI3YmYwNDRiZDM3IiwidHlwZSI6ImFjY2VzcyIsInN1YiI6MTAsIm5iZiI6MTczMTc3ODM1MSwiY3NyZiI6IjcyZmNkMjMyLWNhYjYtNDUzYy05YTIzLTI1ODk0Y2IwMDhjMSIsImV4cCI6MTczMTgyMTU1MX0.Bh4G3UIX4_Dgd-xZqjKZJyGEDwTMghmYHM6mRcihoOY",
    "message": "success",
    "refresh_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJmcmVzaCI6ZmFsc2UsImlhdCI6MTczMTc3ODM1MSwianRpIjoiMGNjMTE5MTctNDgxMi00NDhhLWEzYzQtNzExZTdiYjg0MDQ4IiwidHlwZSI6InJlZnJlc2giLCJzdWIiOjEwLCJuYmYiOjE3MzE3NzgzNTEsImNzcmYiOiI3YmFmMTkyZi00ZDhiLTQ4ODQtYjhmNS1hOWIwMDQ2YzhhOTEiLCJleHAiOjE3MzQzNzAzNTF9.acT34aDsy7-k-o545-OJ7p1DCvVTvrjEJmFdQwjnp2w"
}
POST/api/user/refreshRefresh Token
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "access_token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJmcmVzaCI6ZmFsc2UsImlhdCI6MTczMTc3OTcyNiwianRpIjoiODUxY2VkNjctNjAxYS00MThlLWI2NmItMzBlNWQ5ODdmYmMyIiwidHlwZSI6ImFjY2VzcyIsInN1YiI6MTAsIm5iZiI6MTczMTc3OTcyNiwiY3NyZiI6ImFhZGZhYTE1LTZiY2ItNGZmYi1hMWYzLTcyNWMxYmY3ZjRjZSIsImV4cCI6MTczMTgyMjkyNn0.Fy8mRRBC-X2tqXZAKflUCqtozksL54Ya9CMgJdGY43M",
    "message": "success"
}
GET/api/user/profileView Account Details
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "email": "[email protected]",
    "register_time": "Sat, 24 Jun 2023 19:59:15 GMT",
    "last_visited": "Fri, 15 Nov 2024 18:55:08 GMT",
    "my_recipes": {
        "recipes": 78,
        "favorites": 17,
        "categories": 7
    },
    "shopping_lists": 3,
    "meal_planner": {
        "recipes_prepared": {
            "total": 79,
            "past_week": 6,
            "past_month": 15,
            "past_year": 73
        },
        "days_cooked": {
            "past_week": 5,
            "past_month": 12,
            "past_year": 57
        }
    }
}

My Recipes

GET/api/my-recipes/allView All Recipes
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
page
(query)
1
(integer)
per_page
(query)
1000
(integer)
sort
(query)
title, title_desc, category, category_desc, time_created, time_created_desc
(string)
Response Exampleapplication/json

Status: 200

{
    "recipes": [
        {
            "id": "7945a85b",
            "title": "Almond Flour-Crusted Chicken Piccata",
            "category": "Entrees",
            "photo": "a1d9d9369fa0d43c.jpg"
        },
        {
            "id": "2d7b4296",
            "title": "Balsamic Bacon Brussel Sprouts ",
            "category": "Sides",
            "photo": "b47357c12971393c.jpeg"
        },
        {
            "id": "e728b9d0",
            "title": "Best Beef Enchiladas",
            "category": "Entrees",
            "photo": "2a529e97572b7e0a.jpg"
        }
    ]
}
GET/api/my-recipes/favoritesView Favorites
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
page
(query)
1
(integer)
per_page
(query)
1000
(integer)
sort
(query)
title, title_desc, category, category_desc, time_created, time_created_desc
(string)
Response Exampleapplication/json

Status: 200

{
    "recipes": [
        {
            "id": "045c6509",
            "title": "Carrabba’s-Style Spiedino Di Mare Scallops",
            "category": "Entrees",
            "photo": "c798135ed5a42de2.jpg"
        },
        {
            "id": "e691f3a5",
            "title": "Cashew Chicken Lettuce Wraps",
            "category": "Entrees",
            "photo": "6346812361d9d4ef.jpg"
        },
        {
            "id": "38a8c084",
            "title": "Cheesy Broccoli Cassrole",
            "category": "Sides",
            "photo": "162a3b745e91e1c9.jpeg"
        }
    ]
}
POST/api/my-recipes/recipe/addAdd Recipe
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Request Exampleapplication/json
{
    "title":"Apple Pie", 
    "category":"Miscellaneous",
    "ingredients": [
        "1 tsp olive oil",
        "2 tsp honey"
    ],
    "instructions": [
        "preheat oven to 425",
        "bake for 30 mins"
    ],
    "photo": "",
    "n_calories": null,
    "n_carbs": "",
    "n_protein": null,
    "n_fat": ""
}
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}
GET/api/my-recipes/recipe/{id}View Recipe
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "id": "7945a85b",
    "time_created": "Sat, 24 Jun 2023 20:35:47 GMT",
    "time_edited": null,
    "favorite": 0,
    "public": 0,
    "title": "Almond Flour-Crusted Chicken Piccata",
    "category": "Entrees",
    "photo": "a1d9d9369fa0d43c.jpg",
    "description": "Prepare to delight your taste buds with this exquisite Chicken Piccata recipe, offering a gluten-free take on the beloved Italian classic. With a golden almond flour crust and a tangy, flavorful sauce, each bite is a symphony of texture and taste.",
    "url": "",
    "servings": null,
    "prep_time": 15,
    "cook_time": 15,
    "total_time": 30,
    "ingredients": [
        "2 large eggs",
        "Kosher salt",
        "3/4 cup almond flour",
        "Freshly ground black pepper",
        "Four 5-ounce chicken breast cutlets",
        "2 tablespoons extra-virgin olive oil",
        "1 garlic clove, finely chopped",
        "1/2 cup white wine",
        "1/2 cup chicken stock",
        "3 tablespoons capers, drained",
        "2 tablespoons lemon juice",
        "2 tablespoons unsalted butter",
        "2 tablespoons chopped parsley"
    ],
    "instructions": [
        "In a medium bowl, beat the eggs with 1/2 teaspoon salt. Toss the almond flour with 1/2 teaspoon salt and 1/4 teaspoon pepper and spread the mixture on a large plate. Dip each chicken cutlet in the egg, letting any excess drip back into the bowl, then coat the chicken with the almond flour.",
        "In a large heavy skillet, heat the oil over medium high heat. Add the chicken and brown it, turning once, 5 to 6 minutes total. Transfer the chicken to a plate.",
        "Add the garlic to the skillet and cook, stirring, until golden, 2 to 3 minutes. Stir in the wine, stock, capers, lemon juice and 1/4 teaspoon each of salt and pepper; boil until the sauce is reduced by half. Whisk in the butter until combined, then return the chicken to the skillet and let it gently cook through, about 2 minutes. Sprinkle the chicken with the parsley and serve."
    ]
}
PUT/api/my-recipes/recipe/{id}/editEdit Recipe
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Request Exampleapplication/json
{
    "title":"Apple Pie",
    "category":"Miscellaneous",
    "ingredients": [
        "1 tsp olive oil",
        "2 tsp honey"
    ],
    "instructions": [
        "preheat oven to 425",
        "bake for 30 mins"
    ],
    "n_calories": null,
    "n_carbs": ""
}
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}
DELETE/api/my-recipes/recipe/{id}/removeRemove Recipe
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}
PUT/api/my-recipes/recipe/{id}/favoriteFavorite Recipe
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}
PUT/api/my-recipes/recipe/{id}/unfavoriteUnfavorite Recipe
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}
PUT/api/my-recipes/recipe/{id}/make-publicMake Recipe Public
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}
PUT/api/my-recipes/recipe/{id}/make-privateMake Recipe Private
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}
GET/api/my-recipes/categoriesView Categories
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "categories": [
        {
            "id": "0ef03da9",
            "label": "Breakfast",
            "recipes": 1
        },
        {
            "id": "6ae1a417",
            "label": "Entrees",
            "recipes": 37
        },
        {
            "id": "82deb3d7",
            "label": "Miscellaneous",
            "recipes": 4
        },
        {
            "id": "24bfc543",
            "label": "Sauces",
            "recipes": 5
        },
        {
            "id": "22dc532c",
            "label": "Sides",
            "recipes": 28
		}
	]
}
POST/api/my-recipes/categories/addAdd Category
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Request Exampleapplication/json
{
    "label": "Breakfast"
}
Response Exampleapplication/json

Status: 200

{
    "message": "Success",
    "id": "78ab350f"
}
DELETE/api/my-recipes/categories/{id}/removeRemove Category
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}

Shopping Lists

GET/api/shopping-listsView Shopping Lists
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "shopping_lists": [
        {
            "id": "a2cef182",
            "label": "Costco",
            "list_items": 17
        },
        {
            "id": "3ec2ff29",
            "label": "Miscellaneous",
            "list_items": 12
        }
    ]
}
GET/api/shopping-lists/{id}View List Items
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "list_items": [
        {
            "id": "cf7536ef05",
            "label": "(4) yellow squash",
            "recipe": null,
            "complete": 1
        },
        {
            "id": "8e4434f3d6",
            "label": "Grated Parmesan cheese",
            "recipe": "Air Fryer Potatoes",
            "complete": 1
        },
        {
            "id": "ade3f63f26",
            "label": "Kosher Salt",
            "recipe": "Roasted Asparagus Parmesan",
            "complete": 0
        }
    ]
}
POST/api/shopping-lists/addAdd Shopping List
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Request Exampleapplication/json
{
    "list": "Walmart"
}
Response Exampleapplication/json

Status: 200

{
    "message": "Success",
    "id": "78ab350f"
}
POST/api/shopping-lists/{id}/addAdd Item to List
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Request Exampleapplication/json
{
    "item": "wild caught salmon"
}
Response Exampleapplication/json

Status: 200

{
    "message": "Success",
    "id": "78ab350f"
}
DELETE/api/shopping-lists/{id}/removeRemove Shopping List
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}
PUT/api/shopping-lists/item/{id}/markMark List Item
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success",
    "complete: 1
}
DELETE/api/shopping-lists/item/{id}/removeRemove List Item
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}

Meal Planner

GET/api/meal-planner/allView All Plans
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
page
(query)
1
(integer)
per_page
(query)
1000
(integer)
sort
(query)
desc, asc
(string)
Response Exampleapplication/json

Status: 200

{
    "meals": [
        {
            "id": "784c38afe3",
            "date": "2024-07-28",
            "recipe_id": "f1590a77",
            "recipe_title": "Air Fryer Potatoes",
            "recipe_category": "Sides"
        },
        {
            "id": "584c8928a4",
            "date": "2024-07-28",
            "recipe_id": "7ca75b55",
            "recipe_title": "Braised Cauliflower with Garlic and White Wine",
            "recipe_category": "Sides"
        },
        {
            "id": "8a9477f06d",
            "date": "2024-07-14",
            "recipe_id": "1add59e1",
            "recipe_title": "Chicken Divan",
            "recipe_category": "Entrees"
        }
    ]
}
GET/api/meal-planner/upcomingView Upcoming Plans
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
page
(query)
1
(integer)
per_page
(query)
1000
(integer)
sort
(query)
desc, asc
(string)
Response Exampleapplication/json

Status: 200

{
    "meals": [
        {
            "id": "784c38afe3",
            "date": "2024-07-28",
            "recipe_id": "f1590a77",
            "recipe_title": "Air Fryer Potatoes",
            "recipe_category": "Sides"
        },
        {
            "id": "584c8928a4",
            "date": "2024-07-28",
            "recipe_id": "7ca75b55",
            "recipe_title": "Braised Cauliflower with Garlic and White Wine",
            "recipe_category": "Sides"
        },
        {
            "id": "8a9477f06d",
            "date": "2024-07-14",
            "recipe_id": "1add59e1",
            "recipe_title": "Chicken Divan",
            "recipe_category": "Entrees"
        }
    ]
}
GET/api/meal-planner/completedView Completed Plans
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
page
(query)
1
(integer)
per_page
(query)
1000
(integer)
sort
(query)
desc, asc
(string)
Response Exampleapplication/json

Status: 200

{
    "meals": [
        {
            "id": "784c38afe3",
            "date": "2024-07-28",
            "recipe_id": "f1590a77",
            "recipe_title": "Air Fryer Potatoes",
            "recipe_category": "Sides"
        },
        {
            "id": "584c8928a4",
            "date": "2024-07-28",
            "recipe_id": "7ca75b55",
            "recipe_title": "Braised Cauliflower with Garlic and White Wine",
            "recipe_category": "Sides"
        },
        {
            "id": "8a9477f06d",
            "date": "2024-07-14",
            "recipe_id": "1add59e1",
            "recipe_title": "Chicken Divan",
            "recipe_category": "Entrees"
        }
    ]
}
DELETE/api/meal-planner/{id}/removeRemove Plan
Parameters
Parameter Values
Authorization
(header) (required)
Bearer {access_token}
(string)
Response Exampleapplication/json

Status: 200

{
    "message": "Success"
}

Version 1.1