Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(Excel) Faire - Update Inventory LevelsSee more Faire ExamplesUpdate the inventory levels for multiple product options in one request. For more information, see https://faire.github.io/external-api-docs/#update-inventory-levels
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. Dim http As Chilkat.Http Set http = Chilkat.NewHttp ' Implements the following CURL command: ' curl -X PATCH ' -H "Content-Type: application/json" ' -H "X-FAIRE-ACCESS-TOKEN: <access_token>" ' -d '{ ' "inventories": [ ' { ' "sku": "vanilla-candle", ' "current_quantity": 24, ' "discontinued": false, ' "backordered_until": null ' }, ' { ' "sku": "cinnamon-candle", ' "current_quantity": 0, ' "discontinued": false, ' "backordered_until": "20190314T000915.000Z" ' }, ' { ' "sku": "fall-candle", ' "current_quantity": 0, ' "discontinued": true, ' "backordered_until": null ' }, ' { ' "sku": "fall-candle", ' "current_quantity": null, ' "discontinued": false, ' "backordered_until": null ' } ' ] ' }' https://www.faire.com/api/v1/products/options/inventory-levels ' Use the following online tool to generate HTTP code from a CURL command ' Convert a cURL Command to HTTP Source Code ' Use this online tool to generate code from sample JSON: ' Generate Code to Create JSON ' The following JSON is sent in the request body. ' { ' "inventories": [ ' { ' "sku": "vanilla-candle", ' "current_quantity": 24, ' "discontinued": false, ' "backordered_until": null ' }, ' { ' "sku": "cinnamon-candle", ' "current_quantity": 0, ' "discontinued": false, ' "backordered_until": "20190314T000915.000Z" ' }, ' { ' "sku": "fall-candle", ' "current_quantity": 0, ' "discontinued": true, ' "backordered_until": null ' }, ' { ' "sku": "fall-candle", ' "current_quantity": null, ' "discontinued": false, ' "backordered_until": null ' } ' ] ' } Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject Dim success As Boolean success = json.UpdateString("inventories[0].sku","vanilla-candle") success = json.UpdateInt("inventories[0].current_quantity",24) success = json.UpdateBool("inventories[0].discontinued",False) success = json.UpdateNull("inventories[0].backordered_until") success = json.UpdateString("inventories[1].sku","cinnamon-candle") success = json.UpdateInt("inventories[1].current_quantity",0) success = json.UpdateBool("inventories[1].discontinued",False) success = json.UpdateString("inventories[1].backordered_until","20190314T000915.000Z") success = json.UpdateString("inventories[2].sku","fall-candle") success = json.UpdateInt("inventories[2].current_quantity",0) success = json.UpdateBool("inventories[2].discontinued",True) success = json.UpdateNull("inventories[2].backordered_until") success = json.UpdateString("inventories[3].sku","fall-candle") success = json.UpdateNull("inventories[3].current_quantity") success = json.UpdateBool("inventories[3].discontinued",False) success = json.UpdateNull("inventories[3].backordered_until") http.SetRequestHeader "Content-Type","application/json" http.SetRequestHeader "X-FAIRE-ACCESS-TOKEN","<access_token>" Dim sbRequestBody As Chilkat.StringBuilder Set sbRequestBody = Chilkat.NewStringBuilder success = json.EmitSb(sbRequestBody) Set resp = http.PTextSb("PATCH","https://www.faire.com/api/v1/products/options/inventory-levels",sbRequestBody,"utf-8","application/json",False,False) If (http.LastMethodSuccess = False) Then Debug.Print http.LastErrorText Exit Sub End If Dim sbResponseBody As Chilkat.StringBuilder Set sbResponseBody = Chilkat.NewStringBuilder success = resp.GetBodySb(sbResponseBody) Dim jResp As Chilkat.JsonObject Set jResp = Chilkat.NewJsonObject success = jResp.LoadSb(sbResponseBody) jResp.EmitCompact = False Debug.Print "Response Body:" Debug.Print jResp.Emit() respStatusCode = resp.StatusCode Debug.Print "Response Status Code = "; respStatusCode If (respStatusCode >= 400) Then Debug.Print "Response Header:" Debug.Print resp.Header Debug.Print "Failed." Exit Sub End If ' Sample JSON response: ' (Sample code for parsing the JSON response is shown below) ' { ' "options": [ ' { ' "id": "po_012", ' "product_id": "p_ghi", ' "active": false, ' "deleted": false, ' "name": "Fall Scent", ' "sku": "fall-candle", ' "available_quantity": 0, ' "created_at": "20190313T000915.000Z", ' "updated_at": "20190315T000915.000Z", ' "variations": [ ' { ' "name": "Scent", ' "value": "Fall" ' } ' ], ' "retail_price_cents": 599, ' "wholesale_price_cents": 300 ' }, ' { ' "id": "po_789", ' "product_id": "p_def", ' "active": false, ' "deleted": false, ' "name": "Cinnamon Scent", ' "sku": "cinnamon-candle", ' "available_quantity": 0, ' "created_at": "20190312T000915.000Z", ' "updated_at": "20190315T000915.000Z", ' "backordered_until": "20190314T000915.000Z", ' "variations": [ ' { ' "name": "Scent", ' "value": "Cinnamon" ' } ' ], ' "retail_price_cents": 599, ' "wholesale_price_cents": 300 ' }, ' { ' "id": "po_456", ' "product_id": "p_abc", ' "active": true, ' "deleted": false, ' "name": "Vanilla Scent", ' "sku": "vanilla-candle", ' "available_quantity": 24, ' "created_at": "20190314T000915.000Z", ' "updated_at": "20190315T000915.000Z", ' "variations": [ ' { ' "name": "Scent", ' "value": "Vanilla" ' } ' ], ' "retail_price_cents": 599, ' "wholesale_price_cents": 300 ' } ' ] ' } ' Sample code for parsing the JSON response... ' Use the following online tool to generate parsing code from sample JSON: ' Generate Parsing Code from JSON i = 0 count_i = jResp.SizeOfArray("options") Do While i < count_i jResp.I = i id = jResp.StringOf("options[i].id") product_id = jResp.StringOf("options[i].product_id") active = jResp.BoolOf("options[i].active") deleted = jResp.BoolOf("options[i].deleted") name = jResp.StringOf("options[i].name") sku = jResp.StringOf("options[i].sku") available_quantity = jResp.IntOf("options[i].available_quantity") created_at = jResp.StringOf("options[i].created_at") updated_at = jResp.StringOf("options[i].updated_at") retail_price_cents = jResp.IntOf("options[i].retail_price_cents") wholesale_price_cents = jResp.IntOf("options[i].wholesale_price_cents") backordered_until = jResp.StringOf("options[i].backordered_until") j = 0 count_j = jResp.SizeOfArray("options[i].variations") Do While j < count_j jResp.J = j name = jResp.StringOf("options[i].variations[j].name") value = jResp.StringOf("options[i].variations[j].value") j = j + 1 Loop i = i + 1 Loop |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.