Objective-C
Objective-C
Shopware 6 - Create Product
See more Shopware 6 Examples
Create a new product.Chilkat Objective-C Downloads
#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;
}