...
The Trustwell Genesis 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 |
---|
Only Administrators with API Access will have the ability to generate an API Key. 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:
Log into the Genesis Foods application.
Generate an API Key.
Only Administrators with API Access will have the ability to generate an API Key.
Include this API Key in the request headers for every request you make.
...
In the lower left, click the vertical ellipsis next to your Organization Name / Username.
Select Profile.
Image AddedSelect API Tokens along the top.
Image AddedClick Create API Token.
Enter a Label.
Click Create Token.
Once created, we recommend using the Copy button to copy the string to the clipboard. Image 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.
Include this API Key in the request headers for every request you make.
Example API Key Format
Code Block |
---|
{
"X-API-KEY": "XXXYYYYBBBBZZZZ"
} |
...
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 http 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 your Account Manager Trustwell Support for assistance.
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.
In the examples below, many responses have been truncated for readability.
...
Searching for foods is a key action that users utilize to build recipes.
Search results are paginated.
...
Expand |
---|
|
Query Code Block |
---|
|
|
query($input: FoodSearchInput!){
foods{ Code Block |
---|
|
query($input: FoodSearchInput!){
foods{
search(input: $input)
{
foodSearchResults{
id
name
modified
created
versionName
foodType
product
supplier
isApproved
versionHistoryId
}
totalCount
pageInfo{
cursor
hasNextPage
startCursor
endCursor
search(input: $input) }
{ }
}
} |
GraphQL Variables
Code Block |
---|
|
{
foodSearchResults"input":{
"searchText":"recipe",
id"foodTypes":["Ingredient", "Recipe"],
"itemSourceFilter":"All",
"versionFilter":"Latest"
name }
} |
Expand |
---|
|
Code Block |
---|
| "data": {
"foods": {
modified "search": {
created "foodSearchResults": [
versionName foodType...
product {
supplier "id": "423f0ddd-14b2-4114-8323-7f8ccc11ddac",
isApproved versionHistoryId "name": "granola, prepared from recipe",
} totalCount "modified": "2023-03-27T16:57:27.4906008+00:00",
pageInfo{ cursor "created": "2023-03-27T16:57:27.4838005+00:00",
hasNextPage "versionName": "V1",
startCursor endCursor "foodType": "Ingredient",
} } } } |
GraphQL Variables Code Block |
---|
| { "inputproduct":{
"searchText":"recipe"USDA",
"foodTypes":["Ingredient", "Recipe"], "itemSourceFilter":"All", "versionFiltersupplier": "Latest"USDA SR-Legacy",
} } |
|
Expand |
---|
|
Code Block |
---|
| "data": { "foods": { "isApproved": true,
"search": { "foodSearchResultsversionHistoryId": ["4b7f32ab-3bae-469d-bce8-2dfd28b726d0"
...},
{
"id": "423f0ddd21b52b33-14b22fde-4114498e-83239a44-7f8ccc11ddac5023f98260b4",
"name": "granolataffy, prepared from recipe",
"modified": "2023-03-27T1627T18:5753:2740.49060083575528+00:00",
"created": "2023-03-27T1627T18:5753:2740.48380053504859+00:00",
"versionName": "V1",
"foodType": "Ingredient",
"product": "USDACanadian Nutrient File",
"supplier": "USDA SR-LegacyHealth Canada (Canadian Nutrient File)",
"isApproved": true,
"versionHistoryId": "4b7f32abfb308722-3bae32c1-469d45c8-bce88666-2dfd28b726d042ba8e0a329c"
},
{
"id": "21b52b33a7eaee32-2fde6ecd-498e4ece-9a4490d0-5023f98260b448300d9d4439",
"name": "taffydivinity, prepared from recipe recipe",
"modified": "2023-03-27T17:44:05.6121672+00:00",
"modifiedcreated": "2023-03-27T1827T17:5344:4005.35755286036143+00:00",
"createdversionName": "2023-03-27T18:53:40.3504859+00:00V1",
"versionNamefoodType": "V1Ingredient",
"foodTypeproduct": "IngredientUSDA",
"productsupplier": "Canadian Nutrient FileUSDA SR-Legacy",
"supplierisApproved": "Health Canada (Canadian Nutrient File)",
true,
"versionHistoryId": "db00f784-1a0d-4b14-a4cd-dd53b8487475"
},
"isApproved": true, ...
"versionHistoryId": "fb308722-32c1-45c8-8666-42ba8e0a329c" ],
}, "totalCount": 1407,
{ "pageInfo": {
"idcursor": "a7eaee32-6ecd-4ece-90d0-48300d9d4439",
10,
"namehasNextPage": "divinity, prepared from recipe",true,
"modifiedstartCursor": "2023-03-27T17:44:05.6121672+00:00"0,
"endCursor": 1407
"created": "2023-03-27T17:44:05.6036143+00:00", }
}
}
"versionName": "V1", }
} |
|
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 |
---|
|
Query Code Block |
---|
| query($input : GetAnalysisInput!){
analysis{
getAnalysis(input: $input){
"foodType": "Ingredient", analysis{
"product": "USDA",analysisType
nutrientInfos{
"supplier": "USDA SR-Legacy", nutrient{
"isApproved": true, id
"versionHistoryId": "db00f784-1a0d-4b14-a4cd-dd53b8487475" name
}, }
... value
], }
"totalCount": 1407, amountAnalyzed{
"pageInfo": { quantity{
"cursor": 10, value
"hasNextPage": true, }
"startCursor": 0, unit{
"endCursor": 1407 } name
} }
} } |
|
Getting an Analysis
Expand |
---|
|
Query Code Block |
---|
| query($input : GetAnalysisInput!){ analysis{ }
getAnalysis(input: $input){ analysisweight{
analysisType quantity{
nutrientInfos{ value
nutrient{ }
id unit{
name name
} }
value }
}
}
}
amountAnalyzed} |
GraphQL Variables Code Block |
---|
{
"input":{
"foodId":"855f573f-9977-4625-8241-c6a3ee847b84",
quantity"analysisInput":{
"analysisType": "Net",
value"amount":{
"quantity":"100",
} "unitId":"a7df0af5-0008-0000-7484-751e8eaf05c6"
unit{ }
}
}
} |
|
Expand |
---|
|
Code Block |
---|
| "data": {
name "analysis": {
"getAnalysis": {
} "analysis": }{
weight{ "analysisType": "Net",
quantity{ "nutrientInfos": [
value {
} unit"nutrient": {
name "id": "84a8709a-0000-0000-ebf9-90cea7d9d44f",
} } "name": "Calories"
} } } } |
GraphQL Variables Code Block |
---|
{ "input":{ },
"foodId":"855f573f-9977-4625-8241-c6a3ee847b84", "analysisInput":{ "analysisTypevalue": "Net", 258
"amount":{ },
"quantity":"100", "unitId":"a7df0af5-0008-0000-7484-751e8eaf05c6"{
} } } } |
|
Expand |
---|
|
Code Block |
---|
| "data"nutrient": {
"analysis": { "getAnalysis": { "id": "84a8709a-0001-0000-ebf9-90cea7d9d44f",
"analysis": { "analysisTypename": "NetProtein",
"nutrientInfos": [ },
{ "value": 5.9
"nutrient": { },
{
"id": "84a8709a-0000-0000-ebf9-90cea7d9d44f", "nutrient": {
"name": "Calories" "id": "84a8709a-0002-0000-ebf9-90cea7d9d44f",
}, "valuename": 258"Carbohydrates"
},
{ "value": 57.8
"nutrient": { },
"id": "84a8709a-0001-0000-ebf9-90cea7d9d44f", {
"name": "Protein" "nutrient": {
}, "id": "84a8709a-00cf-0000-ebf9-90cea7d9d44f",
"value": 5.9 "name": "Salt"
}, {},
"nutrientvalue": {1.8725
},
"id": "84a8709a-0002-0000-ebf9-90cea7d9d44f", ...
"name": "Carbohydrates" ],
"amountAnalyzed": {
}, "quantity": {
"value": 57.8 "value": "100"
}, },
"unit": {
"nutrientname": {"Gram"
}
"id": "84a8709a-00cf-0000-ebf9-90cea7d9d44f", },
"nameweight": "Salt"
{
"quantity": {
}, "value": 1.8725"100"
},
"unit": {
... "name": "Gram"
], "amountAnalyzed":}
{ }
"quantity": { }
}
"value": "100" }
}
} |
|
Querying Standard Entities
There are several examples of standard entities in the data. These include units of measure, products, suppliers, etc.
...
Expand |
---|
|
Query Code Block |
---|
| query{
units{
getStandard
}, {
units{
"unit": { id
"name": "Gram"
dimension
} }
}
}
}, |
|
Expand |
---|
|
Code Block |
---|
| {
"data": {
"weightunits": {
"quantity": {
"getStandard": {
"valueunits": "100"[
{
}, "unitid": {
"f14819b2-e1b6-4f8b-9b85-08d43583ec09",
"name": "GramIndividual Carton",
}"dimension": "Discrete"
},
} {
} } }
} |
|
Querying Standard Entities
There are several examples of standard entities in the data. These include units of measure, products, suppliers, etc.
Expand |
---|
|
Query Code Block |
---|
| query{
units{"id": "e92dc923-6da8-4fe1-9380-6564201d70c2",
"name": "Kit",
getStandard { "dimension": "Discrete"
units{ },
id name {
dimension "id": "a7df0af5-0001-0000-7484-751e8eaf05c6",
} } } } |
|
Expand |
---|
|
Code Block |
---|
| { "dataname": {"Teaspoon",
"units": { "getStandarddimension": { "Volume"
"units": [ },
{
"id": "f14819b2a7df0af5-e1b60002-4f8b0000-9b857484-08d43583ec09751e8eaf05c6",
"name": "Individual CartonTablespoon",
"dimension": "DiscreteVolume"
},
{
"id": "e92dc923a7df0af5-6da80003-4fe10000-93807484-6564201d70c2751e8eaf05c6",
"name": "KitCup",
"dimension": "DiscreteVolume"
},
{
"id": "a7df0af5-0001-0000-7484-751e8eaf05c6", ...
"name": "Teaspoon", ]
}
"dimension": "Volume" }
}
} |
|
Creating an Ingredient
...
Expand |
---|
|
Mutation Code Block |
---|
| mutation($input : CreateFoodInput!){
foods{
}, create(input:$input)
{
{ food{
"id": "a7df0af5-0002-0000-7484-751e8eaf05c6",
name
"name": "Tablespoon", definingAmount{
"dimension": "Volume" quantity{
}, value
{ }
"id": "a7df0af5-0003-0000-7484-751e8eaf05c6", unit{
"name": "Cup", id
"dimension": "Volume" name
},
}
... conversions{
] from{
} } } } |
|
Creating an Ingredient
Expand |
---|
|
Mutation Code Block |
---|
| mutation($input : CreateFoodInput!)quantity{
foods{ create(input:$input) { value
food{ id }
name unit{
definingAmount{ quantity{id
value name
} }
unit{ }
id to{
name quantity{
} value
} conversions{ }
from{ unit{
quantity{ id
value name
} }
unit{ }
}
id }
}
}
} |
GraphQL Variables Code Block |
---|
| {
name"input":{
"name":"Test Ingredient Name",
"foodType":"Ingredient"
}
} |
|
Expand |
---|
|
Code Block |
---|
| {
"data": {
"foods": {
} "create": {
to{ "food": {
quantity{ "id": "bd975a4b-5bc0-4e8a-885d-a9c1f586125b",
"name": "Test Ingredient Name",
value "definingAmount": {
} unit"quantity": {
id
"value": "100"
},
name "unit": {
} } "id": "a7df0af5-0008-0000-7484-751e8eaf05c6",
} } "name": "Gram"
} } } |
GraphQL Variables Code Block |
---|
| { "input":{ "name":"Test Ingredient Name", }
"foodType":"Ingredient" } } |
|
Expand |
---|
|
Code Block |
---|
| { "data": { },
"foods": { "create": {conversions": [
"food": { {
"id": "bd975a4b-5bc0-4e8a-885d-a9c1f586125b", "from": {
"name": "Test Ingredient Name", "definingAmountquantity": {
"quantity": { "value": "1"
"value": "100" },
}, "unit": {
"id": "a7df0af5-00080063-0000-7484-751e8eaf05c6",
-751e8eaf05c6",
"name": "Gram" }
"name": "Batch Weight"
}, }
"conversions": [ {},
"fromto": {
"quantity": {
"value": "1100"
},
"unit": {
"id": "a7df0af5-00630008-0000-7484-751e8eaf05c6",
"name": "Batch Weight""Gram"
}
}
} },
},{
"tofrom": {
"quantity": {
"value": "100"
},
"unit": {
"id": "a7df0af5-0008-0000-7484-751e8eaf05c6",
"name": "Gram"
}
}
},
{ "from"to": {
"quantity": {
"value": "1001"
},
"unit": {
"id": "a7df0af5-00080064-0000-7484-751e8eaf05c6",
"name": "Gram" "name": "Batch Yield"
} },
}
"to": { }
"quantity": { ]
}
"value": "1" }
}
}
} |
|
Creating a Recipe
...
Expand |
---|
|
Mutation Code Block |
---|
mutation($input : CreateFoodInput!){
foods{
},create(input:$input)
{
food{
"unit": { id
name
"id": "a7df0af5-0064-0000-7484-751e8eaf05c6", }
}
}
} |
GraphQL Variables Code Block |
---|
{
"input":{
"name":"Test Recipe Name"Batch,
Yield" "foodType":"Recipe"
}
} |
|
Expand |
---|
|
Code Block |
---|
{
"data": {
"foods": {
} "create": {
"food": }{
"id": "0f33eb79-7ba1-48eb-acd6-1f8c22858cea",
} "name": "Test Recipe ]Name"
}
}
}
}
} |
|
...