Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Xojo Plugin) Shopify Create a new product with multiple product variantsCreate a new product with multiple product variants
Dim rest As New Chilkat.Rest Dim success As Boolean success = rest.SetAuthBasic("SHOPIFY_PRIVATE_API_KEY","SHOPIFY_PRIVATE_API_KEY") success = rest.Connect("chilkat.myshopify.com",443,True,True) If (success <> True) Then System.DebugLog(rest.LastErrorText) Return End If // The following code creates the JSON request body. // The JSON created by this code is shown below. Dim jsonReq As New Chilkat.JsonObject success = jsonReq.UpdateString("product.title","Burton Custom Freestyle 151") success = jsonReq.UpdateString("product.body_html","<strong>Good snowboard!</strong>") success = jsonReq.UpdateString("product.vendor","Burton") success = jsonReq.UpdateString("product.product_type","Snowboard") success = jsonReq.UpdateString("product.variants[0].option1","First") success = jsonReq.UpdateString("product.variants[0].price","10.00") success = jsonReq.UpdateString("product.variants[0].sku","123") success = jsonReq.UpdateString("product.variants[1].option1","Second") success = jsonReq.UpdateString("product.variants[1].price","20.00") success = jsonReq.UpdateString("product.variants[1].sku","123") // The JSON request body created by the above code: // { // "product": { // "title": "Burton Custom Freestyle 151", // "body_html": "<strong>Good snowboard!<\/strong>", // "vendor": "Burton", // "product_type": "Snowboard", // "variants": [ // { // "option1": "First", // "price": "10.00", // "sku": "123" // }, // { // "option1": "Second", // "price": "20.00", // "sku": "123" // } // ] // } // } Dim sbReq As New Chilkat.StringBuilder success = jsonReq.EmitSb(sbReq) success = rest.AddHeader("Content-Type","application/json") Dim sbJson As New Chilkat.StringBuilder success = rest.FullRequestSb("POST","/admin/products.json ",sbReq,sbJson) If (success <> True) Then System.DebugLog(rest.LastErrorText) Return End If If (rest.ResponseStatusCode <> 201) Then System.DebugLog("Received error response code: " + Str(rest.ResponseStatusCode)) System.DebugLog("Response body:") System.DebugLog(sbJson.GetAsString()) Return End If Dim json As New Chilkat.JsonObject success = json.LoadSb(sbJson) // The following code parses the JSON response. // A sample JSON response is shown below the sample code. Dim productId As Int32 Dim productTitle As String Dim productBody_html As String Dim productVendor As String Dim productProduct_type As String Dim productCreated_at As String Dim productHandle As String Dim productUpdated_at As String Dim productPublished_at As String Dim productTemplate_suffix As Boolean Dim productPublished_scope As String Dim productTags As String Dim productImage As Boolean Dim i As Int32 Dim count_i As Int32 Dim id As Int32 Dim product_id As Int32 Dim title As String Dim price As String Dim sku As String Dim position As Int32 Dim grams As Int32 Dim inventory_policy As String Dim compare_at_price As Boolean Dim fulfillment_service As String Dim inventory_management As Boolean Dim option1 As String Dim option2 As Boolean Dim option3 As Boolean Dim created_at As String Dim updated_at As String Dim taxable As Boolean Dim barcode As Boolean Dim image_id As Boolean Dim inventory_quantity As Int32 Dim weight As Int32 Dim weight_unit As String Dim old_inventory_quantity As Int32 Dim requires_shipping As Boolean Dim name As String Dim j As Int32 Dim count_j As Int32 Dim strVal As String productId = json.IntOf("product.id") productTitle = json.StringOf("product.title") productBody_html = json.StringOf("product.body_html") productVendor = json.StringOf("product.vendor") productProduct_type = json.StringOf("product.product_type") productCreated_at = json.StringOf("product.created_at") productHandle = json.StringOf("product.handle") productUpdated_at = json.StringOf("product.updated_at") productPublished_at = json.StringOf("product.published_at") productTemplate_suffix = json.IsNullOf("product.template_suffix") productPublished_scope = json.StringOf("product.published_scope") productTags = json.StringOf("product.tags") productImage = json.IsNullOf("product.image") i = 0 count_i = json.SizeOfArray("product.variants") While i < count_i json.I = i id = json.IntOf("product.variants[i].id") product_id = json.IntOf("product.variants[i].product_id") title = json.StringOf("product.variants[i].title") price = json.StringOf("product.variants[i].price") sku = json.StringOf("product.variants[i].sku") position = json.IntOf("product.variants[i].position") grams = json.IntOf("product.variants[i].grams") inventory_policy = json.StringOf("product.variants[i].inventory_policy") compare_at_price = json.IsNullOf("product.variants[i].compare_at_price") fulfillment_service = json.StringOf("product.variants[i].fulfillment_service") inventory_management = json.IsNullOf("product.variants[i].inventory_management") option1 = json.StringOf("product.variants[i].option1") option2 = json.IsNullOf("product.variants[i].option2") option3 = json.IsNullOf("product.variants[i].option3") created_at = json.StringOf("product.variants[i].created_at") updated_at = json.StringOf("product.variants[i].updated_at") taxable = json.BoolOf("product.variants[i].taxable") barcode = json.IsNullOf("product.variants[i].barcode") image_id = json.IsNullOf("product.variants[i].image_id") inventory_quantity = json.IntOf("product.variants[i].inventory_quantity") weight = json.IntOf("product.variants[i].weight") weight_unit = json.StringOf("product.variants[i].weight_unit") old_inventory_quantity = json.IntOf("product.variants[i].old_inventory_quantity") requires_shipping = json.BoolOf("product.variants[i].requires_shipping") i = i + 1 Wend i = 0 count_i = json.SizeOfArray("product.options") While i < count_i json.I = i id = json.IntOf("product.options[i].id") product_id = json.IntOf("product.options[i].product_id") name = json.StringOf("product.options[i].name") position = json.IntOf("product.options[i].position") j = 0 count_j = json.SizeOfArray("product.options[i].values") While j < count_j json.J = j strVal = json.StringOf("product.options[i].values[j]") j = j + 1 Wend i = i + 1 Wend i = 0 count_i = json.SizeOfArray("product.images") While i < count_i json.I = i i = i + 1 Wend // A sample JSON response body that is parsed by the above code: // { // "product": { // "id": 1071559755, // "title": "Burton Custom Freestyle 151", // "body_html": "<strong>Good snowboard!<\/strong>", // "vendor": "Burton", // "product_type": "Snowboard", // "created_at": "2017-09-22T14:48:54-04:00", // "handle": "burton-custom-freestyle-151", // "updated_at": "2017-09-22T14:48:55-04:00", // "published_at": "2017-09-22T14:48:54-04:00", // "template_suffix": null, // "published_scope": "global", // "tags": "", // "variants": [ // { // "id": 1070325225, // "product_id": 1071559755, // "title": "First", // "price": "10.00", // "sku": "123", // "position": 1, // "grams": 0, // "inventory_policy": "deny", // "compare_at_price": null, // "fulfillment_service": "manual", // "inventory_management": null, // "option1": "First", // "option2": null, // "option3": null, // "created_at": "2017-09-22T14:48:54-04:00", // "updated_at": "2017-09-22T14:48:54-04:00", // "taxable": true, // "barcode": null, // "image_id": null, // "inventory_quantity": 1, // "weight": 0.0, // "weight_unit": "lb", // "old_inventory_quantity": 1, // "requires_shipping": true // }, // { // "id": 1070325226, // "product_id": 1071559755, // "title": "Second", // "price": "20.00", // "sku": "123", // "position": 2, // "grams": 0, // "inventory_policy": "deny", // "compare_at_price": null, // "fulfillment_service": "manual", // "inventory_management": null, // "option1": "Second", // "option2": null, // "option3": null, // "created_at": "2017-09-22T14:48:54-04:00", // "updated_at": "2017-09-22T14:48:54-04:00", // "taxable": true, // "barcode": null, // "image_id": null, // "inventory_quantity": 1, // "weight": 0.0, // "weight_unit": "lb", // "old_inventory_quantity": 1, // "requires_shipping": true // } // ], // "options": [ // { // "id": 1022828915, // "product_id": 1071559755, // "name": "Title", // "position": 1, // "values": [ // "First", // "Second" // ] // } // ], // "images": [ // ], // "image": null // } // } System.DebugLog("Example Completed.") |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.