Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(VBScript) 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
Dim fso, outFile Set fso = CreateObject("Scripting.FileSystemObject") 'Create a Unicode (utf-16) output text file. Set outFile = fso.CreateTextFile("output.txt", True, True) ' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Http") set http = CreateObject("Chilkat.Http") ' 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 ' } ' ] ' } ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject") set json = CreateObject("Chilkat.JsonObject") success = json.UpdateString("inventories[0].sku","vanilla-candle") success = json.UpdateInt("inventories[0].current_quantity",24) success = json.UpdateBool("inventories[0].discontinued",0) 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",0) 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",1) 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",0) success = json.UpdateNull("inventories[3].backordered_until") http.SetRequestHeader "Content-Type","application/json" http.SetRequestHeader "X-FAIRE-ACCESS-TOKEN","<access_token>" ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbRequestBody = CreateObject("Chilkat.StringBuilder") success = json.EmitSb(sbRequestBody) ' resp is a Chilkat.HttpResponse Set resp = http.PTextSb("PATCH","https://www.faire.com/api/v1/products/options/inventory-levels",sbRequestBody,"utf-8","application/json",0,0) If (http.LastMethodSuccess = 0) Then outFile.WriteLine(http.LastErrorText) WScript.Quit End If ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbResponseBody = CreateObject("Chilkat.StringBuilder") success = resp.GetBodySb(sbResponseBody) ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject") set jResp = CreateObject("Chilkat.JsonObject") success = jResp.LoadSb(sbResponseBody) jResp.EmitCompact = 0 outFile.WriteLine("Response Body:") outFile.WriteLine(jResp.Emit()) respStatusCode = resp.StatusCode outFile.WriteLine("Response Status Code = " & respStatusCode) If (respStatusCode >= 400) Then outFile.WriteLine("Response Header:") outFile.WriteLine(resp.Header) outFile.WriteLine("Failed.") WScript.Quit 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 outFile.Close |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.