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
(Visual Basic 6.0) Shopware 6 - Find Product by NameSee more Shopware 6 ExamplesFind a product with a given name and get the id.
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. Dim http As New ChilkatHttp Dim success As Long ' 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 Dim json As New ChilkatJsonObject success = json.UpdateString("filter[0].type","equals") success = json.UpdateString("filter[0].field","name") success = json.UpdateString("filter[0].value","Test123") success = json.UpdateString("includes.product[0]","id") success = json.UpdateString("includes.product[1]","name") ' ' Load the access token previously obtained in Shopware 6 OAuth2 Client Credentials Dim jsonToken As New ChilkatJsonObject success = 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. Dim resp As ChilkatHttpResponse Set resp = http.PostJson3("https://my-shopware-6-shop.de/api/v3/search/product","application/json",json) If (http.LastMethodSuccess = 0) Then Debug.Print http.LastErrorText Exit Sub End If Dim sbResponseBody As New ChilkatStringBuilder success = resp.GetBodySb(sbResponseBody) Dim jResp As New ChilkatJsonObject success = jResp.LoadSb(sbResponseBody) jResp.EmitCompact = 0 Debug.Print "Response Body:" Debug.Print jResp.Emit() ' If we get a 401 response, it may be that our access token expired and we need to fetch a new one. Dim respStatusCode As Long respStatusCode = resp.StatusCode Debug.Print "Response Status Code = " & respStatusCode If (respStatusCode >= 400) Then Debug.Print "Response Header:" Debug.Print resp.Header Debug.Print "Failed." Exit Sub End If ' 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": [ ' ] ' } Dim numSearchResults As Long numSearchResults = jResp.SizeOfArray("data") If (numSearchResults <> 1) Then Debug.Print "numSearchResults = " & numSearchResults Debug.Print "Did not find the product, or unexpectedly found more than one with the same name." Exit Sub End If Dim productId As String productId = jResp.StringOf("data[0].id") Debug.Print "Product ID = " & productId |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.