Sample code for 30+ languages & platforms
Objective-C

Shopware 6 - Create Product

See more Shopware 6 Examples

Create a new product.

Chilkat Objective-C Downloads

Objective-C
#import <CkoHttp.h>
#import <CkoJsonObject.h>
#import <CkoHttpResponse.h>
#import <CkoStringBuilder.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];

// Sends the following POST

// POST /api/v3/product/
// {
//     "name" : "Test123",
//     "productNumber" : "random",
//     "stock" : 10,
//     "price" : [
//         {
//             "currencyId" : "b7d2554b0ce847cd82f3ac9bd1c0dfca", 
//             "gross": 15, 
//             "net": 10, 
//             "linked" : false
//         }
//     ],
//     "tax" : {
//         "name": "test", 
//         "taxRate": 15
//     }    
// }

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

// Create a product named "Test123"
CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"name" value: @"Test123"];
[json UpdateString: @"productNumber" value: @"XYZ-1234"];
[json UpdateInt: @"stock" value: [NSNumber numberWithInt: 10]];
[json UpdateString: @"price[0].currencyId" value: @"b7d2554b0ce847cd82f3ac9bd1c0dfca"];
[json UpdateInt: @"price[0].gross" value: [NSNumber numberWithInt: 15]];
[json UpdateInt: @"price[0].net" value: [NSNumber numberWithInt: 10]];
[json UpdateBool: @"price[0].linked" value: NO];
[json UpdateString: @"tax.name" value: @"test"];
[json UpdateInt: @"tax.taxRate" value: [NSNumber numberWithInt: 15]];

// 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"];

CkoHttpResponse *resp = [[CkoHttpResponse alloc] init];
success = [http HttpJson: @"POST" url: @"https://my-shopware-6-shop.de/api/v3/product" 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 successful response is a 204 response status code with an empty response body.
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;
}