Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Objective-C) Shopware 6 - Find Product by NameSee more Shopware 6 ExamplesFind a product with a given name and get the id.
#import <CkoHttp.h> #import <CkoJsonObject.h> #import <CkoHttpResponse.h> #import <CkoStringBuilder.h> #import <NSString.h> // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. CkoHttp *http = [[CkoHttp alloc] init]; BOOL success; // 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 = [http PostJson3: @"https://my-shopware-6-shop.de/api/v3/search/product" contentType: @"application/json" json: json]; if (http.LastMethodSuccess == 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); |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.