Unicode C
Unicode C
Shopware 6 - Rename Category
See more Shopware 6 Examples
Changes the name of an existing category.Chilkat Unicode C Downloads
#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);
}