Sample code for 30+ languages & platforms
Unicode C

Shopware 6 - Rename Category

See more Shopware 6 Examples

Changes the name of an existing category.

Chilkat Unicode C Downloads

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

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

    success = FALSE;

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

    http = CkHttpW_Create();

    // You'll need to know the category's id to update the name.
    // See Find Shopware Category by Name for example code.

    // Load the access token previously obtained in Shopware 6 OAuth2 Client Credentials
    jsonToken = CkJsonObjectW_Create();
    CkJsonObjectW_LoadFile(jsonToken,L"qa_data/tokens/shopware6.json");

    // This causes the "Authorization: Bearer <access_token>" header to be added.
    CkHttpW_putAuthToken(http,CkJsonObjectW_stringOf(jsonToken,L"access_token"));

    // Send a PATCH request where the category id is in the path and the new name is in the JSON body, like this:
    // PATCH /api/v3/category/ab6e524bf224404cb4b675a76550b8cd
    // {
    //     "name": "new_category_name"
    // }

    categoryId = L"ab6e524bf224404cb4b675a76550b8cd";

    sbUrl = CkStringBuilderW_Create();
    CkStringBuilderW_Append(sbUrl,L"https://my-shopware-6-shop.de/api/v3/category/");
    CkStringBuilderW_Append(sbUrl,categoryId);

    // Rename the category to "TestABC"
    json = CkJsonObjectW_Create();
    CkJsonObjectW_UpdateString(json,L"name",L"TestABC");

    url = CkStringBuilderW_getAsString(sbUrl);
    resp = CkHttpResponseW_Create();
    success = CkHttpW_HttpJson(http,L"PATCH",url,json,L"application/json",resp);
    if (success == FALSE) {
        wprintf(L"%s\n",CkHttpW_lastErrorText(http));
        CkHttpW_Dispose(http);
        CkJsonObjectW_Dispose(jsonToken);
        CkStringBuilderW_Dispose(sbUrl);
        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);

    // A 204 response status code indicates success.
    // The response body will be empty when successful.
    wprintf(L"Response Body:\n");
    wprintf(L"%s\n",CkJsonObjectW_emit(jResp));

    // If we get a 401 response, it may be that our access token expired and we need to fetch a new one.
    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(jsonToken);
        CkStringBuilderW_Dispose(sbUrl);
        CkJsonObjectW_Dispose(json);
        CkHttpResponseW_Dispose(resp);
        CkStringBuilderW_Dispose(sbResponseBody);
        CkJsonObjectW_Dispose(jResp);
        return;
    }



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

    }