Sample code for 30+ languages & platforms
VBScript

Faire - Update Inventory Levels

See more Faire Examples

Update the inventory levels for multiple product options in one request.

Chilkat VBScript Downloads

VBScript
Dim fso, outFile
Set fso = CreateObject("Scripting.FileSystemObject")
'Create a Unicode (utf-16) output text file.
Set outFile = fso.CreateTextFile("output.txt", True, True)

success = 0

' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

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
'     }
'   ]
' }

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>"

set sbRequestBody = CreateObject("Chilkat.StringBuilder")
success = json.EmitSb(sbRequestBody)

set resp = CreateObject("Chilkat.HttpResponse")
success = http.HttpSb("PATCH","https://www.faire.com/api/v1/products/options/inventory-levels",sbRequestBody,"utf-8","application/json",resp)
If (success = 0) Then
    outFile.WriteLine(http.LastErrorText)
    WScript.Quit
End If

set sbResponseBody = CreateObject("Chilkat.StringBuilder")
success = resp.GetBodySb(sbResponseBody)

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