Visual FoxPro
Visual FoxPro
Shopify Set inventory levels to a certain amount
See more Shopify Examples
Use the set endpoint with the location ID and inventory item ID to set an inventory level to a specific value.Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJsonRequestBody
LOCAL lcUrl
LOCAL loResp
LOCAL loJsonResponse
LOCAL lnInventory_levelInventory_item_id
LOCAL lnInventory_levelLocation_id
LOCAL lnInventory_levelAvailable
LOCAL lcInventory_levelUpdated_at
LOCAL lcInventory_levelAdmin_graphql_api_id
lnSuccess = 0
* This example requires the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
loHttp = CreateObject('Chilkat.Http')
loHttp.Login = "SHOPIFY_PRIVATE_API_KEY"
loHttp.Password = "SHOPIFY_PRIVATE_API_KEY"
* Also see: How to retrieve inventory levels
loHttp.Accept = "application/json"
* The following JSON is sent in the request body:
* {
* "location_id": 6884556842,
* "inventory_item_id": 12250274365496,
* "available": 1
* }
* Use this online tool to generate the code from sample JSON:
* Generate Code to Create JSON
loJsonRequestBody = CreateObject('Chilkat.JsonObject')
loJsonRequestBody.UpdateInt("location_id",6884556842)
loJsonRequestBody.UpdateInt("inventory_item_id",12250274365496)
loJsonRequestBody.UpdateInt("available",1)
lcUrl = "https://{shop}.myshopify.com/admin/api/2020-04/inventory_levels/set.json"
loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpJson("POST",lcUrl,loJsonRequestBody,"application/json",loResp)
IF (lnSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loHttp
RELEASE loJsonRequestBody
RELEASE loResp
CANCEL
ENDIF
? "Response Status Code: " + STR(loResp.StatusCode)
loJsonResponse = CreateObject('Chilkat.JsonObject')
loJsonResponse.Load(loResp.BodyStr)
loJsonResponse.EmitCompact = 0
? loJsonResponse.Emit()
IF (loResp.StatusCode >= 300) THEN
? "Failed."
RELEASE loHttp
RELEASE loJsonRequestBody
RELEASE loResp
RELEASE loJsonResponse
CANCEL
ENDIF
* 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_level": {
* "inventory_item_id": 12250274365496,
* "location_id": 6884556842,
* "available": 1,
* "updated_at": "2018-06-26T15:44:33-04:00",
* ...
* "admin_graphql_api_id": "gid://shopify/InventoryLevel/6485147690?inventory_item_id=12250274365496"
* ...
* }
* }
*
lnInventory_levelInventory_item_id = loJsonResponse.IntOf("inventory_level.inventory_item_id")
lnInventory_levelLocation_id = loJsonResponse.IntOf("inventory_level.location_id")
lnInventory_levelAvailable = loJsonResponse.IntOf("inventory_level.available")
lcInventory_levelUpdated_at = loJsonResponse.StringOf("inventory_level.updated_at")
lcInventory_levelAdmin_graphql_api_id = loJsonResponse.StringOf("inventory_level.admin_graphql_api_id")
RELEASE loHttp
RELEASE loJsonRequestBody
RELEASE loResp
RELEASE loJsonResponse