Unicode C
Unicode C
Shopify Retrieve the item's inventory levels
See more Shopify Examples
After you have the inventory item ID, you can use it with the InventoryLevel resource to find the levels and locations for the inventory item:Chilkat Unicode C Downloads
#include <C_CkHttpW.h>
#include <C_CkHttpResponseW.h>
#include <C_CkJsonObjectW.h>
void ChilkatSample(void)
{
BOOL success;
HCkHttpW http;
HCkHttpResponseW resp;
HCkJsonObjectW jsonResponse;
int inventory_item_id;
int location_id;
int available;
const wchar_t *updated_at;
const wchar_t *admin_graphql_api_id;
int i;
int count_i;
success = FALSE;
// This example requires the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http = CkHttpW_Create();
CkHttpW_putLogin(http,L"SHOPIFY_PRIVATE_API_KEY");
CkHttpW_putPassword(http,L"SHOPIFY_PRIVATE_API_KEY");
CkHttpW_putAccept(http,L"application/json");
// How to get the inventory item ID
resp = CkHttpResponseW_Create();
success = CkHttpW_HttpNoBody(http,L"GET",L"https://{shop}.myshopify.com/admin/api/2020-04/inventory_levels.json?inventory_item_ids={inventory_item_id}",resp);
if (success == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkHttpW_Dispose(http);
CkHttpResponseW_Dispose(resp);
return;
}
wprintf(L"Response Status Code: %d\n",CkHttpResponseW_getStatusCode(resp));
jsonResponse = CkJsonObjectW_Create();
CkJsonObjectW_Load(jsonResponse,CkHttpResponseW_bodyStr(resp));
CkJsonObjectW_putEmitCompact(jsonResponse,FALSE);
wprintf(L"%s\n",CkJsonObjectW_emit(jsonResponse));
if (CkHttpResponseW_getStatusCode(resp) != 200) {
wprintf(L"Failed.\n");
CkHttpW_Dispose(http);
CkHttpResponseW_Dispose(resp);
CkJsonObjectW_Dispose(jsonResponse);
return;
}
// Sample output...
// (See the parsing code below..)
//
// Use the this online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
// {
// "inventory_levels": [
// {
// "inventory_item_id": 12250274365496,
// "location_id": 6884556842,
// "available": 8,
// "updated_at": "2018-06-18T11:49:50-04:00",
// "admin_graphql_api_id": "gid://shopify/InventoryLevel/6485147690?inventory_item_id=12250274365496"
// },
// {
// "inventory_item_id": 12250274365496,
// "location_id": 13968834616,
// "available": 50,
// "updated_at": "2018-06-26T14:44:30-04:00",
// "admin_graphql_api_id": "gid://shopify/InventoryLevel/13570506808?inventory_item_id=12250274365496"
// },
// {
// "inventory_item_id": 12250274365496,
// "location_id": 13968867384,
// "available": 100,
// "updated_at": "2018-06-26T14:44:30-04:00",
// "admin_graphql_api_id": "gid://shopify/InventoryLevel/13570539576?inventory_item_id=12250274365496"
// }
// ]
// }
//
i = 0;
count_i = CkJsonObjectW_SizeOfArray(jsonResponse,L"inventory_levels");
while (i < count_i) {
CkJsonObjectW_putI(jsonResponse,i);
inventory_item_id = CkJsonObjectW_IntOf(jsonResponse,L"inventory_levels[i].inventory_item_id");
location_id = CkJsonObjectW_IntOf(jsonResponse,L"inventory_levels[i].location_id");
available = CkJsonObjectW_IntOf(jsonResponse,L"inventory_levels[i].available");
updated_at = CkJsonObjectW_stringOf(jsonResponse,L"inventory_levels[i].updated_at");
admin_graphql_api_id = CkJsonObjectW_stringOf(jsonResponse,L"inventory_levels[i].admin_graphql_api_id");
i = i + 1;
}
CkHttpW_Dispose(http);
CkHttpResponseW_Dispose(resp);
CkJsonObjectW_Dispose(jsonResponse);
}