Xojo Plugin
Xojo Plugin
WooCommerce List All Products
See more WooCommerce Examples
Gets WooCommerce product information in JSON format.Chilkat Xojo Plugin Downloads
Dim success As Boolean
success = False
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
Dim http As New Chilkat.Http
// Implements the following CURL command:
// curl https://example.com/wp-json/wc/v3/products \
// -u consumer_key:consumer_secret
// Use the following online tool to generate HTTP code from a CURL command
// Convert a cURL Command to HTTP Source Code
http.BasicAuth = True
http.Login = "consumer_key"
http.Password = "consumer_secret"
Dim sbResponseBody As New Chilkat.StringBuilder
success = http.QuickGetSb("https://example.com/wp-json/wc/v3/products",sbResponseBody)
If (success = False) Then
System.DebugLog(http.LastErrorText)
Return
End If
Dim jarrResp As New Chilkat.JsonArray
success = jarrResp.LoadSb(sbResponseBody)
jarrResp.EmitCompact = False
System.DebugLog("Response Body:")
System.DebugLog(jarrResp.Emit())
Dim respStatusCode As Int32
respStatusCode = http.LastStatus
System.DebugLog("Response Status Code = " + Str(respStatusCode))
If (respStatusCode >= 400) Then
System.DebugLog("Response Header:")
System.DebugLog(http.LastHeader)
System.DebugLog("Failed.")
Return
End If
// Sample JSON response:
// (Sample code for parsing the JSON response is shown below)
// [
// {
// "id": 799,
// "name": "Ship Your Idea",
// "slug": "ship-your-idea-22",
// "permalink": "https://example.com/product/ship-your-idea-22/",
// "date_created": "2017-03-23T17:03:12",
// "date_created_gmt": "2017-03-23T20:03:12",
// "date_modified": "2017-03-23T17:03:12",
// "date_modified_gmt": "2017-03-23T20:03:12",
// "type": "variable",
// "status": "publish",
// "featured": false,
// "catalog_visibility": "visible",
// "description": "<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo.</p>\n",
// "short_description": "<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas.</p>\n",
// "sku": "",
// "price": "",
// "regular_price": "",
// "sale_price": "",
// "date_on_sale_from": null,
// "date_on_sale_from_gmt": null,
// "date_on_sale_to": null,
// "date_on_sale_to_gmt": null,
// "price_html": "",
// "on_sale": false,
// "purchasable": false,
// "total_sales": 0,
// "virtual": false,
// "downloadable": false,
// "downloads": [
// ],
// "download_limit": -1,
// "download_expiry": -1,
// "external_url": "",
// "button_text": "",
// "tax_status": "taxable",
// "tax_class": "",
// "manage_stock": false,
// "stock_quantity": null,
// "stock_status": "instock",
// "backorders": "no",
// "backorders_allowed": false,
// "backordered": false,
// "sold_individually": false,
// "weight": "",
// "dimensions": {
// "length": "",
// "width": "",
// "height": ""
// },
// "shipping_required": true,
// "shipping_taxable": true,
// "shipping_class": "",
// "shipping_class_id": 0,
// "reviews_allowed": true,
// "average_rating": "0.00",
// "rating_count": 0,
// "related_ids": [
// 31,
// 22,
// 369,
// 414,
// 56
// ],
// "upsell_ids": [
// ],
// "cross_sell_ids": [
// ],
// "parent_id": 0,
// "purchase_note": "",
// "categories": [
// {
// "id": 9,
// "name": "Clothing",
// "slug": "clothing"
// },
// {
// "id": 14,
// "name": "T-shirts",
// "slug": "t-shirts"
// }
// ],
// "tags": [
// ],
// "images": [
// {
// "id": 795,
// "date_created": "2017-03-23T14:03:08",
// "date_created_gmt": "2017-03-23T20:03:08",
// "date_modified": "2017-03-23T14:03:08",
// "date_modified_gmt": "2017-03-23T20:03:08",
// "src": "https://example.com/wp-content/uploads/2017/03/T_4_front-11.jpg",
// "name": "",
// "alt": ""
// },
// {
// "id": 796,
// "date_created": "2017-03-23T14:03:09",
// "date_created_gmt": "2017-03-23T20:03:09",
// "date_modified": "2017-03-23T14:03:09",
// "date_modified_gmt": "2017-03-23T20:03:09",
// "src": "https://example.com/wp-content/uploads/2017/03/T_4_back-10.jpg",
// "name": "",
// "alt": ""
// },
// {
// "id": 797,
// "date_created": "2017-03-23T14:03:10",
// "date_created_gmt": "2017-03-23T20:03:10",
// "date_modified": "2017-03-23T14:03:10",
// "date_modified_gmt": "2017-03-23T20:03:10",
// "src": "https://example.com/wp-content/uploads/2017/03/T_3_front-10.jpg",
// "name": "",
// "alt": ""
// },
// {
// "id": 798,
// "date_created": "2017-03-23T14:03:11",
// "date_created_gmt": "2017-03-23T20:03:11",
// "date_modified": "2017-03-23T14:03:11",
// "date_modified_gmt": "2017-03-23T20:03:11",
// "src": "https://example.com/wp-content/uploads/2017/03/T_3_back-10.jpg",
// "name": "",
// "alt": ""
// }
// ],
// "attributes": [
// {
// "id": 6,
// "name": "Color",
// "position": 0,
// "visible": false,
// "variation": true,
// "options": [
// "Black",
// "Green"
// ]
// },
// {
// "id": 0,
// "name": "Size",
// "position": 0,
// "visible": true,
// "variation": true,
// "options": [
// "S",
// "M"
// ]
// }
// ],
// "default_attributes": [
// ],
// "variations": [
// ],
// "grouped_products": [
// ],
// "menu_order": 0,
// "meta_data": [
// ],
// "_links": {
// "self": [
// {
// "href": "https://example.com/wp-json/wc/v3/products/799"
// }
// ],
// "collection": [
// {
// "href": "https://example.com/wp-json/wc/v3/products"
// }
// ]
// }
// },
// {
// "id": 794,
// "name": "Premium Quality",
// "slug": "premium-quality-19",
// "permalink": "https://example.com/product/premium-quality-19/",
// "date_created": "2017-03-23T17:01:14",
// "date_created_gmt": "2017-03-23T20:01:14",
// "date_modified": "2017-03-23T17:01:14",
// "date_modified_gmt": "2017-03-23T20:01:14",
// "type": "simple",
// "status": "publish",
// "featured": false,
// "catalog_visibility": "visible",
// "description": "<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo.</p>\n",
// "short_description": "<p>Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas.</p>\n",
// "sku": "",
// "price": "21.99",
// "regular_price": "21.99",
// "sale_price": "",
// "date_on_sale_from": null,
// "date_on_sale_from_gmt": null,
// "date_on_sale_to": null,
// "date_on_sale_to_gmt": null,
// "price_html": "<span class=\"woocommerce-Price-amount amount\"><span class=\"woocommerce-Price-currencySymbol\">$</span>21.99</span>",
// "on_sale": false,
// "purchasable": true,
// "total_sales": 0,
// "virtual": false,
// "downloadable": false,
// "downloads": [
// ],
// "download_limit": -1,
// "download_expiry": -1,
// "external_url": "",
// "button_text": "",
// "tax_status": "taxable",
// "tax_class": "",
// "manage_stock": false,
// "stock_quantity": null,
// "stock_status": "instock",
// "backorders": "no",
// "backorders_allowed": false,
// "backordered": false,
// "sold_individually": false,
// "weight": "",
// "dimensions": {
// "length": "",
// "width": "",
// "height": ""
// },
// "shipping_required": true,
// "shipping_taxable": true,
// "shipping_class": "",
// "shipping_class_id": 0,
// "reviews_allowed": true,
// "average_rating": "0.00",
// "rating_count": 0,
// "related_ids": [
// 463,
// 47,
// 31,
// 387,
// 458
// ],
// "upsell_ids": [
// ],
// "cross_sell_ids": [
// ],
// "parent_id": 0,
// "purchase_note": "",
// "categories": [
// {
// "id": 9,
// "name": "Clothing",
// "slug": "clothing"
// },
// {
// "id": 14,
// "name": "T-shirts",
// "slug": "t-shirts"
// }
// ],
// "tags": [
// ],
// "images": [
// {
// "id": 792,
// "date_created": "2017-03-23T14:01:13",
// "date_created_gmt": "2017-03-23T20:01:13",
// "date_modified": "2017-03-23T14:01:13",
// "date_modified_gmt": "2017-03-23T20:01:13",
// "src": "https://example.com/wp-content/uploads/2017/03/T_2_front-4.jpg",
// "name": "",
// "alt": ""
// },
// {
// "id": 793,
// "date_created": "2017-03-23T14:01:14",
// "date_created_gmt": "2017-03-23T20:01:14",
// "date_modified": "2017-03-23T14:01:14",
// "date_modified_gmt": "2017-03-23T20:01:14",
// "src": "https://example.com/wp-content/uploads/2017/03/T_2_back-2.jpg",
// "name": "",
// "alt": ""
// }
// ],
// "attributes": [
// ],
// "default_attributes": [
// {
// "id": 6,
// "name": "Color",
// "option": "black"
// },
// {
// "id": 0,
// "name": "Size",
// "option": "S"
// }
// ],
// "variations": [
// ],
// "grouped_products": [
// ],
// "menu_order": 0,
// "meta_data": [
// ],
// "_links": {
// "self": [
// {
// "href": "https://example.com/wp-json/wc/v3/products/794"
// }
// ],
// "collection": [
// {
// "href": "https://example.com/wp-json/wc/v3/products"
// }
// ]
// }
// }
// ]
// Sample code for parsing the JSON response...
// Use the following online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
Dim date_created As New Chilkat.DtObj
Dim date_created_gmt As New Chilkat.DtObj
Dim date_modified As New Chilkat.DtObj
Dim date_modified_gmt As New Chilkat.DtObj
Dim date_on_sale_from As New Chilkat.DtObj
Dim date_on_sale_from_gmt As New Chilkat.DtObj
Dim date_on_sale_to As New Chilkat.DtObj
Dim date_on_sale_to_gmt As New Chilkat.DtObj
Dim json As Chilkat.JsonObject
Dim id As Int32
Dim name As String
Dim slug As String
Dim permalink As String
Dim v_type As String
Dim status As String
Dim featured As Boolean
Dim catalog_visibility As String
Dim description As String
Dim short_description As String
Dim sku As String
Dim price As String
Dim regular_price As String
Dim sale_price As String
Dim price_html As String
Dim on_sale As Boolean
Dim purchasable As Boolean
Dim total_sales As Int32
Dim v_virtual As Boolean
Dim downloadable As Boolean
Dim download_limit As Int32
Dim download_expiry As Int32
Dim external_url As String
Dim button_text As String
Dim tax_status As String
Dim tax_class As String
Dim manage_stock As Boolean
Dim stock_quantity As String
Dim stock_status As String
Dim backorders As String
Dim backorders_allowed As Boolean
Dim backordered As Boolean
Dim sold_individually As Boolean
Dim weight As String
Dim dimensionsLength As String
Dim dimensionsWidth As String
Dim dimensionsHeight As String
Dim shipping_required As Boolean
Dim shipping_taxable As Boolean
Dim shipping_class As String
Dim shipping_class_id As Int32
Dim reviews_allowed As Boolean
Dim average_rating As String
Dim rating_count As Int32
Dim parent_id As Int32
Dim purchase_note As String
Dim menu_order As Int32
Dim j As Int32
Dim count_j As Int32
Dim intVal As Int32
Dim src As String
Dim alt As String
Dim position As Int32
Dim visible As Boolean
Dim variation As Boolean
Dim k As Int32
Dim count_k As Int32
Dim strVal As String
Dim v_option As String
Dim href As String
Dim i As Int32
i = 0
Dim count_i As Int32
count_i = jarrResp.Size
While i < count_i
json = jarrResp.ObjectAt(i)
id = json.IntOf("id")
name = json.StringOf("name")
slug = json.StringOf("slug")
permalink = json.StringOf("permalink")
success = json.DtOf("date_created",False,date_created)
success = json.DtOf("date_created_gmt",False,date_created_gmt)
success = json.DtOf("date_modified",False,date_modified)
success = json.DtOf("date_modified_gmt",False,date_modified_gmt)
v_type = json.StringOf("type")
status = json.StringOf("status")
featured = json.BoolOf("featured")
catalog_visibility = json.StringOf("catalog_visibility")
description = json.StringOf("description")
short_description = json.StringOf("short_description")
sku = json.StringOf("sku")
price = json.StringOf("price")
regular_price = json.StringOf("regular_price")
sale_price = json.StringOf("sale_price")
success = json.DtOf("date_on_sale_from",False,date_on_sale_from)
success = json.DtOf("date_on_sale_from_gmt",False,date_on_sale_from_gmt)
success = json.DtOf("date_on_sale_to",False,date_on_sale_to)
success = json.DtOf("date_on_sale_to_gmt",False,date_on_sale_to_gmt)
price_html = json.StringOf("price_html")
on_sale = json.BoolOf("on_sale")
purchasable = json.BoolOf("purchasable")
total_sales = json.IntOf("total_sales")
v_virtual = json.BoolOf("virtual")
downloadable = json.BoolOf("downloadable")
download_limit = json.IntOf("download_limit")
download_expiry = json.IntOf("download_expiry")
external_url = json.StringOf("external_url")
button_text = json.StringOf("button_text")
tax_status = json.StringOf("tax_status")
tax_class = json.StringOf("tax_class")
manage_stock = json.BoolOf("manage_stock")
stock_quantity = json.StringOf("stock_quantity")
stock_status = json.StringOf("stock_status")
backorders = json.StringOf("backorders")
backorders_allowed = json.BoolOf("backorders_allowed")
backordered = json.BoolOf("backordered")
sold_individually = json.BoolOf("sold_individually")
weight = json.StringOf("weight")
dimensionsLength = json.StringOf("dimensions.length")
dimensionsWidth = json.StringOf("dimensions.width")
dimensionsHeight = json.StringOf("dimensions.height")
shipping_required = json.BoolOf("shipping_required")
shipping_taxable = json.BoolOf("shipping_taxable")
shipping_class = json.StringOf("shipping_class")
shipping_class_id = json.IntOf("shipping_class_id")
reviews_allowed = json.BoolOf("reviews_allowed")
average_rating = json.StringOf("average_rating")
rating_count = json.IntOf("rating_count")
parent_id = json.IntOf("parent_id")
purchase_note = json.StringOf("purchase_note")
menu_order = json.IntOf("menu_order")
j = 0
count_j = json.SizeOfArray("downloads")
While j < count_j
json.J = j
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("related_ids")
While j < count_j
json.J = j
intVal = json.IntOf("related_ids[j]")
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("upsell_ids")
While j < count_j
json.J = j
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("cross_sell_ids")
While j < count_j
json.J = j
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("categories")
While j < count_j
json.J = j
id = json.IntOf("categories[j].id")
name = json.StringOf("categories[j].name")
slug = json.StringOf("categories[j].slug")
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("tags")
While j < count_j
json.J = j
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("images")
While j < count_j
json.J = j
id = json.IntOf("images[j].id")
success = json.DtOf("images[j].date_created",False,date_created)
success = json.DtOf("images[j].date_created_gmt",False,date_created_gmt)
success = json.DtOf("images[j].date_modified",False,date_modified)
success = json.DtOf("images[j].date_modified_gmt",False,date_modified_gmt)
src = json.StringOf("images[j].src")
name = json.StringOf("images[j].name")
alt = json.StringOf("images[j].alt")
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("attributes")
While j < count_j
json.J = j
id = json.IntOf("attributes[j].id")
name = json.StringOf("attributes[j].name")
position = json.IntOf("attributes[j].position")
visible = json.BoolOf("attributes[j].visible")
variation = json.BoolOf("attributes[j].variation")
k = 0
count_k = json.SizeOfArray("attributes[j].options")
While k < count_k
json.K = k
strVal = json.StringOf("attributes[j].options[k]")
k = k + 1
Wend
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("default_attributes")
While j < count_j
json.J = j
id = json.IntOf("default_attributes[j].id")
name = json.StringOf("default_attributes[j].name")
v_option = json.StringOf("default_attributes[j].option")
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("variations")
While j < count_j
json.J = j
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("grouped_products")
While j < count_j
json.J = j
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("meta_data")
While j < count_j
json.J = j
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("_links.self")
While j < count_j
json.J = j
href = json.StringOf("_links.self[j].href")
j = j + 1
Wend
j = 0
count_j = json.SizeOfArray("_links.collection")
While j < count_j
json.J = j
href = json.StringOf("_links.collection[j].href")
j = j + 1
Wend
i = i + 1
Wend