Sample code for 30+ languages & platforms
Objective-C

Shopware 6 - Rename Category

See more Shopware 6 Examples

Changes the name of an existing category.

Chilkat Objective-C Downloads

Objective-C
#import <CkoHttp.h>
#import <CkoJsonObject.h>
#import <NSString.h>
#import <CkoStringBuilder.h>
#import <CkoHttpResponse.h>

BOOL success = NO;

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

CkoHttp *http = [[CkoHttp alloc] init];

// 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
CkoJsonObject *jsonToken = [[CkoJsonObject alloc] init];
[jsonToken LoadFile: @"qa_data/tokens/shopware6.json"];

// This causes the "Authorization: Bearer <access_token>" header to be added.
http.AuthToken = [jsonToken StringOf: @"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"
// }

NSString *categoryId = @"ab6e524bf224404cb4b675a76550b8cd";

CkoStringBuilder *sbUrl = [[CkoStringBuilder alloc] init];
[sbUrl Append: @"https://my-shopware-6-shop.de/api/v3/category/"];
[sbUrl Append: categoryId];

// Rename the category to "TestABC"
CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"name" value: @"TestABC"];

NSString *url = [sbUrl GetAsString];
CkoHttpResponse *resp = [[CkoHttpResponse alloc] init];
success = [http HttpJson: @"PATCH" url: url json: json contentType: @"application/json" response: resp];
if (success == NO) {
    NSLog(@"%@",http.LastErrorText);
    return;
}

CkoStringBuilder *sbResponseBody = [[CkoStringBuilder alloc] init];
[resp GetBodySb: sbResponseBody];
CkoJsonObject *jResp = [[CkoJsonObject alloc] init];
[jResp LoadSb: sbResponseBody];
jResp.EmitCompact = NO;

// A 204 response status code indicates success.
// The response body will be empty when successful.
NSLog(@"%@",@"Response Body:");
NSLog(@"%@",[jResp Emit]);

// If we get a 401 response, it may be that our access token expired and we need to fetch a new one.
int respStatusCode = [resp.StatusCode intValue];
NSLog(@"%@%d",@"Response Status Code = ",respStatusCode);
if (respStatusCode >= 400) {
    NSLog(@"%@",@"Response Header:");
    NSLog(@"%@",resp.Header);
    NSLog(@"%@",@"Failed.");
    return;
}