Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

Introduction

The Trustwell Genesis

...

Production: https://api.trustwell.com/genesis

Preview: TBD

Obtaining your API Key

To start using the Genesis Foods API, you need to -

...

Log into the Genesis Foods application

Generate an API Key

...

Foods API provides a powerful way to access food data, perform analyses, query standard entities, and create new ingredients or recipes. Built on GraphQL, the API allows you to define precisely what data you need and retrieve it efficiently. This guide will walk you through how to authenticate and start making queries and mutations using the API.

Obtaining your API Key

Note

Authentication/Authorization

An API Key can be generated in the Genesis Foods application if your user has been given the appropriate permission. Please contact your Account Manager if you don’t see the ability to generate API Keys.

The API Key should be included in the X-API-KEY header with each request.

Code Block
languagejson
{
  "X-API-KEY": "XXXYYYYBBBBZZZZ"
}

Searching

Searching for foods is a key action that users utilize to build recipes. Search results are paginated.

query($input: FoodSearchInput!){ foods{ search(input: $input) {
  • Only Administrators with API Access will have the ability to generate an API Key.

Expand
titleRequest

Query

Code Block
languagejson

...

Send the API Key with every request in the header

...

The API has rate and usage limits

...

The API only responds to HTTPS. Any requests sent via HTTP return an HTTP 301 redirect to corresponding HTTPS resources

...

Genesis Foods API is a GraphQL API with a single endpoint. Read more about working with GraphQL API’s here.

  • Treat your API Key like a password. Keep it secret; keep it safe.

  • For questions, please contact Trustwell Support

To start using the Genesis Foods API, follow these steps:

  1. Log into the Genesis Foods application.

  2. In the lower left, click the vertical ellipsis next to your Organization Name / Username.

  3. Select Profile.

    image-20241010-225201.pngImage Added
  4. Select API Tokens along the top.

    image-20241010-225301.pngImage Added
  5. Click Create API Token.

  6. Enter a Label.

  7. Click Create Token.

  8. Once created, we recommend using the Copy button to copy the string to the clipboard. image-20241010-230028.pngImage Added

    • Important: This is the only time you will be able to obtain this Token. Should this be lost, the Token should be deleted and a new one created.

    • Preserve this Token string as you would other secrets / passwords.

  9. Include this API Key in the request headers for every request you make.

Example API Key Format

Code Block
{ 
  "X-API-KEY": "XXXYYYYBBBBZZZZ" 
}

Notes

  • The API enforces rate and usage limits.

  • Requests are only processed over HTTPS. HTTP requests will be redirected to the corresponding HTTPS resource.

  • The Genesis Foods API uses GraphQL and has a single endpoint. For more information on how GraphQL works, please visit https://graphql.org/.

Authentication/Authorization

You can generate an API Key through the Genesis Foods application, provided your user has the necessary permissions. If you do not have access to generate API Keys, please contact Trustwell Support for assistance.

Include your API Key in the request headers

Code Block
{ 
  "X-API-KEY": "XXXYYYYBBBBZZZZ" 
}


API Reference Documentation

The Genesis Foods GraphQL API reference documentation.

https://docs.trustwell.com/genesis/api/

API Playground

The Genesis Foods GraphQL API Playground with example code.

Genesis Foods GraphQL API Playground

https://github.com/esha/genesis-foods-api-playground

API Operations: Queries and Mutations Examples

The Trustwell Genesis Foods API offers a range of operations that allow you to interact with the system through both queries and mutations. Queries enable you to fetch data, such as searching for foods or retrieving nutritional analysis, while mutations allow you to create or update data, like adding ingredients or recipes. Each operation is designed to be flexible and powerful, giving you control over the specific data you need and minimizing unnecessary overhead.

Below are examples of common API operations, showing how to construct requests and handle responses for both queries and mutations.

Info

Genesis GraphQL API Endpoint

Production: https://api.trustwell.com/genesis

Preview: https://api-preview.trustwell.com/genesis

In the examples below, many responses have been truncated for readability.

Searching

Searching for foods is a key action that users utilize to build recipes.

Search results are paginated.

...

Expand
titleRequest

Query

Code Block
languagejson
query($input: FoodSearchInput!){
    foods{
        search(input: $input)
        {
            foodSearchResults{
                id
                name
                modified
                created
                versionName
                foodType
                product
                supplier
                isApproved
                versionHistoryId
            }
            totalCount
            pageInfo{
                cursor
                hasNextPage
                startCursor
                endCursor
            }
        }
    }
}

GraphQL Variables

Code Block
languagejson
{
    "input":{
        "searchText":"recipe",
        "foodTypes":["Ingredient", "Recipe"],
        "itemSourceFilter":"All",
        "versionFilter":"Latest"
    }
}
Expand
titleResponse
Code Block
languagejson
"data": {
        "foods": {
            "search": {
                "foodSearchResults": [
                    ...
                    {
                        "id": "423f0ddd-14b2-4114-8323-7f8ccc11ddac",
                        "name": "granola, prepared from recipe",
                        "modified": "2023-03-27T16:57:27.4906008+00:00",
                        "created": "2023-03-27T16:57:27.4838005+00:00",
                        "versionName": "V1",
                        "foodType": "Ingredient",
                        "product": "USDA",
                        "supplier": "USDA SR-Legacy",
                        "isApproved": true,
                        "versionHistoryId": "4b7f32ab-3bae-469d-bce8-2dfd28b726d0"
                    },
                    {
                        "id": "21b52b33-2fde-498e-9a44-5023f98260b4",
                        "name": "taffy, prepared from recipe",
                        "modified": "2023-03-27T18:53:40.3575528+00:00",
                        "created": "2023-03-27T18:53:40.3504859+00:00",
                        "versionName": "V1",
                        "foodType": "Ingredient",
                        "product": "Canadian Nutrient File",
                        "supplier": "Health Canada (Canadian Nutrient File)",
                        "isApproved": true,
                        "versionHistoryId": "fb308722-32c1-45c8-8666-42ba8e0a329c"
                    },
                    {
                        "id": "a7eaee32-6ecd-4ece-90d0-48300d9d4439",
                        "name": "divinity, prepared from recipe",
                        "modified": "2023-03-27T17:44:05.6121672+00:00",
                        "created": "2023-03-27T17:44:05.6036143+00:00",
                        "versionName": "V1",
                        "foodType": "Ingredient",
                        "product": "USDA",
                        "supplier": "USDA SR-Legacy",
                        "isApproved": true,
                        "versionHistoryId": "db00f784-1a0d-4b14-a4cd-dd53b8487475"
                    },
                    ...
                ],
                "totalCount": 1407,
                "pageInfo": {
                    "cursor": 10,
                    "hasNextPage": true,
                    "startCursor": 0,
                    "endCursor": 1407
                }
            }
        }
    }
}

Getting an Analysis

Analyzing your foods is a core use case for Genesis. There are 2 types of analyses you can request: Gross and Net.

...

Expand
titleRequest

Query

Code Block
languagegraphql
query($input : GetAnalysisInput!){
    analysis{
        getAnalysis(input: $input){
            analysis{
                analysisType
                nutrientInfos{
                    nutrient{
                        id
                        name
                    }
                    value
                }
                amountAnalyzed{
                    quantity{
                        value
                    }
                    unit{
                        name
                    }
                }
                weight{
                   quantity{
                        value
                    }
                    unit{
                        name
                    } 
                }
            }
        }
    } 
}

GraphQL Variables

Code Block
{
    "input":{
        "foodId":"855f573f-9977-4625-8241-c6a3ee847b84",
        "analysisInput":{
            "analysisType": "Net",
            "amount":{
                "quantity":"100",
                "unitId":"a7df0af5-0008-0000-7484-751e8eaf05c6"
            }
        }
    }
}
Expand
titleResponse
Code Block
languagejson
"data": {
        "analysis": {
            "getAnalysis": {
                "analysis": {
                    "analysisType": "Net",
                    "nutrientInfos": [
                        {
                            "nutrient": {
                                "id": "84a8709a-0000-0000-ebf9-90cea7d9d44f",
                                "name": "Calories"
                            },
                            "value": 258
                        },
                        {
                            "nutrient": {
                                "id": "84a8709a-0001-0000-ebf9-90cea7d9d44f",
                                "name": "Protein"
                            },
                            "value": 5.9
                        },
                        {
                            "nutrient": {
                                "id": "84a8709a-0002-0000-ebf9-90cea7d9d44f",
                                "name": "Carbohydrates"
                            },
                            "value": 57.8
                        },                        
                        {
                            "nutrient": {
                                "id": "84a8709a-00cf-0000-ebf9-90cea7d9d44f",
                                "name": "Salt"
                            },
                            "value": 1.8725
                        },
                        ...
                    ],
                    "amountAnalyzed": {
                        "quantity": {
                            "value": "100"
                        },
                        "unit": {
                            "name": "Gram"
                        }
                    },
                    "weight": {
                        "quantity": {
                            "value": "100"
                        },
                        "unit": {
                            "name": "Gram"
                        }
                    }
                }
            }
        }
    }
}

Querying Standard Entities

There are several examples of standard entities in the data. These include units of measure, products, suppliers, etc.

...

Expand
titleRequest

Query

Code Block
languagegraphql
query{
    units{
        getStandard
        {
            units{
                id
                name
                dimension
            }
        }
    } 
}
Expand
titleResponse
Code Block
languagejson
{
    "data": {
        "units": {
            "getStandard": {
                "units": [
                    {
                        "id": "f14819b2-e1b6-4f8b-9b85-08d43583ec09",
                        "name": "Individual Carton",
                        "dimension": "Discrete"
                    },
                    {
                        "id": "e92dc923-6da8-4fe1-9380-6564201d70c2",
                        "name": "Kit",
                        "dimension": "Discrete"
                    },
                    {
                        "id": "a7df0af5-0001-0000-7484-751e8eaf05c6",
                        "name": "Teaspoon",
                        "dimension": "Volume"
                    },
                    {
                        "id": "a7df0af5-0002-0000-7484-751e8eaf05c6",
                        "name": "Tablespoon",
                        "dimension": "Volume"
                    },
                    {
                        "id": "a7df0af5-0003-0000-7484-751e8eaf05c6",
                        "name": "Cup",
                        "dimension": "Volume"
                    },
                    ...            
                ]
            }
        }
    }
}

Creating an Ingredient

...

Expand
titleRequest

Mutation

Code Block
languagegraphql
mutation($input : CreateFoodInput!){
    foods{
        create(input:$input)
        {
            food{
                id
                name
                definingAmount{
                    quantity{
                        value
                    }
                    unit{
                        id
                        name
                    }
                }
                conversions{
                    from{
                        quantity{
                            value
                        }
                        unit{
                            id
                            name
                        }
                    }
                    to{
                        quantity{
                            value
                        }
                        unit{
                            id
                            name
                        }
                    }
                }
            }
        }
    }
}

GraphQL Variables

Code Block
languagejson
{
    "input":{
        "name":"Test Ingredient Name",
        "foodType":"Ingredient"
    }
}
Expand
titleResponse
Code Block
languagejson
{
    "data": {
        "foods": {
            "create": {
                "food": {
                    "id": "bd975a4b-5bc0-4e8a-885d-a9c1f586125b",
                    "name": "Test Ingredient Name",
                    "definingAmount": {
                        "quantity": {
                            "value": "100"
                        },
                        "unit": {
                            "id": "a7df0af5-0008-0000-7484-751e8eaf05c6",
                            "name": "Gram"
                        }
                    },
                    "conversions": [
                        {
                            "from": {
                                "quantity": {
                foodSearchResults{                 id   "value": "1"
            name                 modified   },
             created                 versionName  "unit": {
             foodType                 product      "id": "a7df0af5-0063-0000-7484-751e8eaf05c6",
         supplier                 isApproved          "name": "Batch Weight"
    versionHistoryId             }             totalCount  }
          pageInfo{                 cursor },
               hasNextPage             "to": {
  startCursor                 endCursor             }"quantity": {
       }     } }

GraphQL Variables

Code Block
languagejson
{     "input":{         "searchText":"recipe",         "foodTypesvalue":["Ingredient", "Recipe100"],
        "itemSourceFilter":"All",         "versionFilter":"Latest"     } }
Expand
titleResponse
Code Block
languagejson
"data": {        },
"foods": {             "search": {                 "foodSearchResultsunit": [{
                    ...                "id": "a7df0af5-0008-0000-7484-751e8eaf05c6",
     {                               "idname": "423f0ddd-14b2-4114-8323-7f8ccc11ddac","Gram"
                              "name": "granola, prepared}
from recipe",                         "modified": "2023-03-27T16:57:27.4906008+00:00",
 }
                       "created": "2023-03-27T16:57:27.4838005+00:00" },
                        "versionName": "V1",{
                            "foodTypefrom": "Ingredient", {
                            "product": "USDA",   "quantity": {
                    "supplier": "USDA SR-Legacy",              "value": "100"
         "isApproved": true,                      },
  "versionHistoryId": "4b7f32ab-3bae-469d-bce8-2dfd28b726d0"                     },        "unit": {
           {                         "id": "21b52b33a7df0af5-2fde0008-498e0000-9a447484-5023f98260b4751e8eaf05c6",
                        "name": "taffy, prepared from recipe",        "name": "Gram"
               "modified": "2023-03-27T18:53:40.3575528+00:00",                   }
     "created": "2023-03-27T18:53:40.3504859+00:00",                      },
  "versionName": "V1",                         "foodTypeto": "Ingredient",{
                        "product": "Canadian Nutrient File",     "quantity": {
                  "supplier": "Health Canada (Canadian Nutrient File)",              "value": "1"
         "isApproved": true,                      },
  "versionHistoryId": "fb308722-32c1-45c8-8666-42ba8e0a329c"                     },        "unit": {
           {                         "id": "a7eaee32a7df0af5-6ecd0064-4ece0000-90d07484-48300d9d4439751e8eaf05c6",
                        "name": "divinity, prepared from recipe",        "name": "Batch  Yield"
             "modified": "2023-03-27T17:44:05.6121672+00:00",                  }
      "created": "2023-03-27T17:44:05.6036143+00:00",                      }
         "versionName": "V1",              }
          "foodType": "Ingredient",         ]
               "product": "USDA", }
            }
        }
  "supplier": "USDA SR-Legacy",
   }
}

Creating a Recipe

...

Expand
titleRequest

Mutation

Code Block
mutation($input : CreateFoodInput!){
    foods{
        create(input:$input)
       "isApproved": true, {
            food{
           "versionHistoryId": "db00f784-1a0d-4b14-a4cd-dd53b8487475"    id
                },name
                 }
  ...          }
      ],  }
}

GraphQL Variables

Code Block
{
    "input":{
        "totalCountname": 1407"Test Recipe Name",
        "foodType":"Recipe"
       }
}
Expand
titleResponse
Code Block
{
    "pageInfodata": {
        "foods": {
            "cursorcreate": 10,{
                    "hasNextPagefood": true,{
                    "startCursorid": 0"0f33eb79-7ba1-48eb-acd6-1f8c22858cea",
                    "endCursorname": 1407"Test Recipe Name"
                }
            }
        }
    }
}

Getting an Analysis

Querying Standard Entities

Creating an Ingredient

...