Objective-C
Objective-C
Shopware 6 - Find Product by Name
See more Shopware 6 Examples
Find a product with a given name and get the id.Chilkat Objective-C Downloads
#import <CkoHttp.h>
#import <CkoJsonObject.h>
#import <CkoHttpResponse.h>
#import <CkoStringBuilder.h>
#import <NSString.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 to find the product named "Test123"
// POST /api/v3/search/product
// {
// "filter": [
// { "type": "equals", "field": "name", "value": "Test123" }
// ],
// "includes": {
// "product": ["id", "name"]
// }
// }
// Create the above JSON.
// Use this online tool to generate code from sample JSON:
// Generate Code to Create JSON
CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"filter[0].type" value: @"equals"];
[json UpdateString: @"filter[0].field" value: @"name"];
[json UpdateString: @"filter[0].value" value: @"Test123"];
[json UpdateString: @"includes.product[0]" value: @"id"];
[json UpdateString: @"includes.product[1]" value: @"name"];
//
// 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"];
// Note: If you get a 401 response status code, then fetch a new access token and retry.
CkoHttpResponse *resp = [[CkoHttpResponse alloc] init];
success = [http HttpJson: @"POST" url: @"https://my-shopware-6-shop.de/api/v3/search/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;
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;
}
// The response looks like this:
// Use the following online tool to generate parsing code from sample JSON:
// Generate Parsing Code from JSON
// {
// "data": [
// {
// "id": "d195dabb53cf46d096bd9a8726d82558",
// "type": "product",
// "attributes": {
// "name": "Test123",
// "apiAlias": null
// },
// "links": {
// "self": "https:\/\/***.de\/api\/v3\/product\/d195dabb53cf46d096bd9a8726d82558"
// },
// "relationships": [
// ],
// "meta": null
// }
// ],
// "included": [
// ],
// "links": {
// "self": "https:\/\/***.de\/api\/v3\/search\/product"
// },
// "meta": {
// "totalCountMode": 0,
// "total": 1
// },
// "aggregations": [
// ]
// }
int numSearchResults = [[jResp SizeOfArray: @"data"] intValue];
if (numSearchResults != 1) {
NSLog(@"%@%d",@"numSearchResults = ",numSearchResults);
NSLog(@"%@",@"Did not find the product, or unexpectedly found more than one with the same name.");
return;
}
NSString *productId = [jResp StringOf: @"data[0].id"];
NSLog(@"%@%@",@"Product ID = ",productId);