Sample code for 30+ languages & platforms
Unicode C++

Shopify Get particular fields of a single product

See more Shopify Examples

Get particular fields of a single product

Chilkat Unicode C++ Downloads

Unicode C++
#include <CkRestW.h>
#include <CkStringBuilderW.h>
#include <CkJsonObjectW.h>

void ChilkatSample(void)
    {
    bool success = false;

    CkRestW rest;

    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;
    }

    CkStringBuilderW sbJson;
    success = rest.FullRequestNoBodySb(L"GET",L"/admin/products/#{id}.json?fields=id,images,title",sbJson);
    if (success != true) {
        wprintf(L"%s\n",rest.lastErrorText());
        return;
    }

    if (rest.get_ResponseStatusCode() != 200) {
        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;
    int i;
    int count_i;
    int id;
    int product_id;
    int position;
    const wchar_t *created_at = 0;
    const wchar_t *updated_at = 0;
    int width;
    int height;
    const wchar_t *src = 0;
    int j;
    int count_j;
    int intVal;

    productId = json.IntOf(L"product.id");
    productTitle = json.stringOf(L"product.title");
    i = 0;
    count_i = json.SizeOfArray(L"product.images");
    while (i < count_i) {
        json.put_I(i);
        id = json.IntOf(L"product.images[i].id");
        product_id = json.IntOf(L"product.images[i].product_id");
        position = json.IntOf(L"product.images[i].position");
        created_at = json.stringOf(L"product.images[i].created_at");
        updated_at = json.stringOf(L"product.images[i].updated_at");
        width = json.IntOf(L"product.images[i].width");
        height = json.IntOf(L"product.images[i].height");
        src = json.stringOf(L"product.images[i].src");
        j = 0;
        count_j = json.SizeOfArray(L"product.images[i].variant_ids");
        while (j < count_j) {
            json.put_J(j);
            intVal = json.IntOf(L"product.images[i].variant_ids[j]");
            j = j + 1;
        }

        i = i + 1;
    }

    // A sample JSON response body that is parsed by the above code:

    // {
    //   "product": {
    //     "id": 632910392,
    //     "title": "IPod Nano - 8GB",
    //     "images": [
    //       {
    //         "id": 850703190,
    //         "product_id": 632910392,
    //         "position": 1,
    //         "created_at": "2017-09-22T14:08:02-04:00",
    //         "updated_at": "2017-09-22T14:08:02-04:00",
    //         "width": 123,
    //         "height": 456,
    //         "src": "https:\/\/cdn.shopify.com\/s\/files\/1\/0006\/9093\/3842\/products\/ipod-nano.png?v=1506103682",
    //         "variant_ids": [
    //         ]
    //       },
    //       {
    //         "id": 562641783,
    //         "product_id": 632910392,
    //         "position": 2,
    //         "created_at": "2017-09-22T14:08:02-04:00",
    //         "updated_at": "2017-09-22T14:08:02-04:00",
    //         "width": 123,
    //         "height": 456,
    //         "src": "https:\/\/cdn.shopify.com\/s\/files\/1\/0006\/9093\/3842\/products\/ipod-nano-2.png?v=1506103682",
    //         "variant_ids": [
    //           808950810
    //         ]
    //       }
    //     ]
    //   }
    // }

    wprintf(L"Example Completed.\n");
    }