Sample code for 30+ languages & platforms
Unicode C

Walmart v3 Item Setup by Match

See more Walmart v3 Examples

Provides a quick and convenient way to set up items by matching your items to existing item content on Walmart.com.

Chilkat Unicode C Downloads

Unicode C
#include <C_CkHttpW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkHttpResponseW.h>
#include <C_CkStringBuilderW.h>

void ChilkatSample(void)
    {
    BOOL success;
    HCkHttpW http;
    HCkJsonObjectW json;
    HCkHttpResponseW resp;
    HCkStringBuilderW sbResponseBody;
    HCkJsonObjectW jResp;
    int respStatusCode;
    const wchar_t *feedId;

    success = FALSE;

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

    http = CkHttpW_Create();

    // Implements the following CURL command:

    // curl -X POST \
    //   https://marketplace.walmartapis.com/v3/feeds?feedType=item \
    //   -H 'WM_SVC.NAME: Walmart Marketplace'
    //   -H 'WM_SEC.ACCESS_TOKEN: eyJraWQiOiIzZjVhYTFmNS1hYWE5LTQzM.....'
    //   -H 'WM_QOS.CORRELATION_ID: b3261d2d-028a-4ef7-8602-633c23200af6'
    //   -H 'Content-Type: application/json'
    //   -H 'Accept: application/json'
    //   -d '{
    //     "MPItemFeedHeader": {
    //         "version": "3.2.1"
    //     },
    //     "MPItem": [
    //         {
    //             "sku": "setup_by_ref",
    //             "productIdentifiers": [
    //                 {
    //                     "productIdType": "GTIN",
    //                     "productId": "05518319011365"
    //                 }
    //             ],
    //             "MPProduct": {
    //                 "category": "Electronics",
    //                 "subCategory": "ElectronicsAccessories"
    //             },
    //             "MPOffer": {
    //                 "price": 12.00,
    //                 "shippingWeight": {
    //                     "measure": 0.5,
    //                     "unit": "lb"
    //                 },
    //                 "productTaxCode": 2038710
    //             }
    //         }
    //     ]
    // }'

    // Use this online tool to generate code from sample JSON:
    // Generate Code to Create JSON

    // The following JSON is sent in the request body.

    // {
    //   "MPItemFeedHeader": {
    //     "version": "3.2.1"
    //   },
    //   "MPItem": [
    //     {
    //       "sku": "setup_by_ref",
    //       "productIdentifiers": [
    //         {
    //           "productIdType": "GTIN",
    //           "productId": "05518319011365"
    //         }
    //       ],
    //       "MPProduct": {
    //         "category": "Electronics",
    //         "subCategory": "ElectronicsAccessories"
    //       },
    //       "MPOffer": {
    //         "price": 12.00,
    //         "shippingWeight": {
    //           "measure": 0.5,
    //           "unit": "lb"
    //         },
    //         "productTaxCode": 2038710
    //       }
    //     }
    //   ]
    // }

    json = CkJsonObjectW_Create();
    CkJsonObjectW_UpdateString(json,L"MPItemFeedHeader.version",L"3.2.1");
    CkJsonObjectW_UpdateString(json,L"MPItem[0].sku",L"setup_by_ref");
    CkJsonObjectW_UpdateString(json,L"MPItem[0].productIdentifiers[0].productIdType",L"GTIN");
    CkJsonObjectW_UpdateString(json,L"MPItem[0].productIdentifiers[0].productId",L"05518319011365");
    CkJsonObjectW_UpdateString(json,L"MPItem[0].MPProduct.category",L"Electronics");
    CkJsonObjectW_UpdateString(json,L"MPItem[0].MPProduct.subCategory",L"ElectronicsAccessories");
    CkJsonObjectW_UpdateNumber(json,L"MPItem[0].MPOffer.price",L"12.00");
    CkJsonObjectW_UpdateNumber(json,L"MPItem[0].MPOffer.shippingWeight.measure",L"0.5");
    CkJsonObjectW_UpdateString(json,L"MPItem[0].MPOffer.shippingWeight.unit",L"lb");
    CkJsonObjectW_UpdateInt(json,L"MPItem[0].MPOffer.productTaxCode",2038710);

    CkHttpW_SetRequestHeader(http,L"WM_QOS.CORRELATION_ID",L"b3261d2d-028a-4ef7-8602-633c23200af6");
    CkHttpW_SetRequestHeader(http,L"Content-Type",L"application/json");
    CkHttpW_SetRequestHeader(http,L"WM_SEC.ACCESS_TOKEN",L"eyJraWQiOiIzZjVhYTFmNS1hYWE5LTQzM.....");
    CkHttpW_SetRequestHeader(http,L"Accept",L"application/json");
    CkHttpW_SetRequestHeader(http,L"WM_SVC.NAME",L"Walmart Marketplace");

    resp = CkHttpResponseW_Create();
    success = CkHttpW_HttpJson(http,L"POST",L"https://marketplace.walmartapis.com/v3/feeds?feedType=item",json,L"application/json",resp);
    if (success == FALSE) {
        wprintf(L"%s\n",CkHttpW_lastErrorText(http));
        CkHttpW_Dispose(http);
        CkJsonObjectW_Dispose(json);
        CkHttpResponseW_Dispose(resp);
        return;
    }

    sbResponseBody = CkStringBuilderW_Create();
    CkHttpResponseW_GetBodySb(resp,sbResponseBody);
    jResp = CkJsonObjectW_Create();
    CkJsonObjectW_LoadSb(jResp,sbResponseBody);
    CkJsonObjectW_putEmitCompact(jResp,FALSE);

    wprintf(L"Response Body:\n");
    wprintf(L"%s\n",CkJsonObjectW_emit(jResp));

    respStatusCode = CkHttpResponseW_getStatusCode(resp);
    wprintf(L"Response Status Code = %d\n",respStatusCode);
    if (respStatusCode >= 400) {
        wprintf(L"Response Header:\n");
        wprintf(L"%s\n",CkHttpResponseW_header(resp));
        wprintf(L"Failed.\n");
        CkHttpW_Dispose(http);
        CkJsonObjectW_Dispose(json);
        CkHttpResponseW_Dispose(resp);
        CkStringBuilderW_Dispose(sbResponseBody);
        CkJsonObjectW_Dispose(jResp);
        return;
    }

    // Sample JSON response:
    // (Sample code for parsing the JSON response is shown below)

    // {
    //   "feedId": "BC141881F6BB4B5891F084B225581BF2@AUUBAQA"
    // }

    // Sample code for parsing the JSON response...
    // Use the following online tool to generate parsing code from sample JSON:
    // Generate Parsing Code from JSON

    feedId = CkJsonObjectW_stringOf(jResp,L"feedId");


    CkHttpW_Dispose(http);
    CkJsonObjectW_Dispose(json);
    CkHttpResponseW_Dispose(resp);
    CkStringBuilderW_Dispose(sbResponseBody);
    CkJsonObjectW_Dispose(jResp);

    }