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
(Unicode C++) Shopify Create a new product with multiple product variantsCreate a new product with multiple product variants
#include <CkRestW.h> #include <CkJsonObjectW.h> #include <CkStringBuilderW.h> void ChilkatSample(void) { CkRestW rest; bool success; rest.SetAuthBasic(L"SHOPIFY_PRIVATE_API_KEY",L"SHOPIFY_PRIVATE_API_KEY"); success = rest.Connect(L"chilkat.myshopify.com",443,true,true); if (success != true) { wprintf(L"%s\n",rest.lastErrorText()); return; } // The following code creates the JSON request body. // The JSON created by this code is shown below. CkJsonObjectW jsonReq; jsonReq.UpdateString(L"product.title",L"Burton Custom Freestyle 151"); jsonReq.UpdateString(L"product.body_html",L"<strong>Good snowboard!</strong>"); jsonReq.UpdateString(L"product.vendor",L"Burton"); jsonReq.UpdateString(L"product.product_type",L"Snowboard"); jsonReq.UpdateString(L"product.variants[0].option1",L"First"); jsonReq.UpdateString(L"product.variants[0].price",L"10.00"); jsonReq.UpdateString(L"product.variants[0].sku",L"123"); jsonReq.UpdateString(L"product.variants[1].option1",L"Second"); jsonReq.UpdateString(L"product.variants[1].price",L"20.00"); jsonReq.UpdateString(L"product.variants[1].sku",L"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" // } // ] // } // } CkStringBuilderW sbReq; jsonReq.EmitSb(sbReq); rest.AddHeader(L"Content-Type",L"application/json"); CkStringBuilderW sbJson; success = rest.FullRequestSb(L"POST",L"/admin/products.json ",sbReq,sbJson); if (success != true) { wprintf(L"%s\n",rest.lastErrorText()); return; } if (rest.get_ResponseStatusCode() != 201) { wprintf(L"Received error response code: %d\n",rest.get_ResponseStatusCode()); wprintf(L"Response body:\n"); wprintf(L"%s\n",sbJson.getAsString()); return; } CkJsonObjectW json; json.LoadSb(sbJson); // The following code parses the JSON response. // A sample JSON response is shown below the sample code. int productId; const wchar_t *productTitle = 0; const wchar_t *productBody_html = 0; const wchar_t *productVendor = 0; const wchar_t *productProduct_type = 0; const wchar_t *productCreated_at = 0; const wchar_t *productHandle = 0; const wchar_t *productUpdated_at = 0; const wchar_t *productPublished_at = 0; bool productTemplate_suffix; const wchar_t *productPublished_scope = 0; const wchar_t *productTags = 0; bool productImage; int i; int count_i; int id; int product_id; const wchar_t *title = 0; const wchar_t *price = 0; const wchar_t *sku = 0; int position; int grams; const wchar_t *inventory_policy = 0; bool compare_at_price; const wchar_t *fulfillment_service = 0; bool inventory_management; const wchar_t *option1 = 0; bool option2; bool option3; const wchar_t *created_at = 0; const wchar_t *updated_at = 0; bool taxable; bool barcode; bool image_id; int inventory_quantity; int weight; const wchar_t *weight_unit = 0; int old_inventory_quantity; bool requires_shipping; const wchar_t *name = 0; int j; int count_j; const wchar_t *strVal = 0; productId = json.IntOf(L"product.id"); productTitle = json.stringOf(L"product.title"); productBody_html = json.stringOf(L"product.body_html"); productVendor = json.stringOf(L"product.vendor"); productProduct_type = json.stringOf(L"product.product_type"); productCreated_at = json.stringOf(L"product.created_at"); productHandle = json.stringOf(L"product.handle"); productUpdated_at = json.stringOf(L"product.updated_at"); productPublished_at = json.stringOf(L"product.published_at"); productTemplate_suffix = json.IsNullOf(L"product.template_suffix"); productPublished_scope = json.stringOf(L"product.published_scope"); productTags = json.stringOf(L"product.tags"); productImage = json.IsNullOf(L"product.image"); i = 0; count_i = json.SizeOfArray(L"product.variants"); while (i < count_i) { json.put_I(i); id = json.IntOf(L"product.variants[i].id"); product_id = json.IntOf(L"product.variants[i].product_id"); title = json.stringOf(L"product.variants[i].title"); price = json.stringOf(L"product.variants[i].price"); sku = json.stringOf(L"product.variants[i].sku"); position = json.IntOf(L"product.variants[i].position"); grams = json.IntOf(L"product.variants[i].grams"); inventory_policy = json.stringOf(L"product.variants[i].inventory_policy"); compare_at_price = json.IsNullOf(L"product.variants[i].compare_at_price"); fulfillment_service = json.stringOf(L"product.variants[i].fulfillment_service"); inventory_management = json.IsNullOf(L"product.variants[i].inventory_management"); option1 = json.stringOf(L"product.variants[i].option1"); option2 = json.IsNullOf(L"product.variants[i].option2"); option3 = json.IsNullOf(L"product.variants[i].option3"); created_at = json.stringOf(L"product.variants[i].created_at"); updated_at = json.stringOf(L"product.variants[i].updated_at"); taxable = json.BoolOf(L"product.variants[i].taxable"); barcode = json.IsNullOf(L"product.variants[i].barcode"); image_id = json.IsNullOf(L"product.variants[i].image_id"); inventory_quantity = json.IntOf(L"product.variants[i].inventory_quantity"); weight = json.IntOf(L"product.variants[i].weight"); weight_unit = json.stringOf(L"product.variants[i].weight_unit"); old_inventory_quantity = json.IntOf(L"product.variants[i].old_inventory_quantity"); requires_shipping = json.BoolOf(L"product.variants[i].requires_shipping"); i = i + 1; } i = 0; count_i = json.SizeOfArray(L"product.options"); while (i < count_i) { json.put_I(i); id = json.IntOf(L"product.options[i].id"); product_id = json.IntOf(L"product.options[i].product_id"); name = json.stringOf(L"product.options[i].name"); position = json.IntOf(L"product.options[i].position"); j = 0; count_j = json.SizeOfArray(L"product.options[i].values"); while (j < count_j) { json.put_J(j); strVal = json.stringOf(L"product.options[i].values[j]"); j = j + 1; } i = i + 1; } i = 0; count_i = json.SizeOfArray(L"product.images"); while (i < count_i) { json.put_I(i); i = i + 1; } // 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 // } // } wprintf(L"Example Completed.\n"); } |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.