Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(Excel) Shopware 6 - Delete CategorySee more Shopware 6 ExamplesDelete a category by name.
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. Dim http As Chilkat.Http Set http = Chilkat.NewHttp ' First, let's search for the category by name because we'll need to know the category's id to delete. ' Sends the following POST ' POST /api/v3/search/category ' { ' "filter": [ ' { "type": "equals", "field": "name", "value": "Test123" } ' ], ' "includes": { ' "category": ["id", "name"] ' } ' } ' Create the above JSON. ' Use this online tool to generate code from sample JSON: ' Generate Code to Create JSON Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject Dim success As Boolean 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.category[0]","id") success = json.UpdateString("includes.category[1]","name") ' Load the access token previously obtained in Shopware 6 OAuth2 Client Credentials Dim jsonToken As Chilkat.JsonObject Set jsonToken = Chilkat.NewJsonObject 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. Set resp = http.PostJson3("https://my-shopware-6-shop.de/api/v3/search/category","application/json",json) If (http.LastMethodSuccess = False) Then Debug.Print http.LastErrorText Exit Sub End If Dim sbResponseBody As Chilkat.StringBuilder Set sbResponseBody = Chilkat.NewStringBuilder success = resp.GetBodySb(sbResponseBody) Dim jResp As Chilkat.JsonObject Set jResp = Chilkat.NewJsonObject success = jResp.LoadSb(sbResponseBody) jResp.EmitCompact = False 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. 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": "89c4131789fd422c8f00cf37bbb83330", ' "type": "category", ' "attributes": { ' "name": "Test123", ' "apiAlias": null ' }, ' "links": { ' "self": "https:\/\/***.de\/api\/v3\/category\/89c4131789fd422c8f00cf37bbb83330" ' }, ' "relationships": [ ' ], ' "meta": null ' } ' ], ' "included": [ ' ], ' "links": { ' "self": "https:\/\/***.de\/api\/v3\/search\/category" ' }, ' "meta": { ' "totalCountMode": 0, ' "total": 1 ' }, ' "aggregations": [ ' ] ' } numSearchResults = jResp.SizeOfArray("data") If (numSearchResults <> 1) Then Debug.Print "numSearchResults = "; numSearchResults Debug.Print "Did not find the category, or unexpectedly found more than one with the same name." Exit Sub End If categoryId = jResp.StringOf("data[0].id") Debug.Print "Category ID = "; categoryId ' ----------------------------------------------------------------------------------------------- ' Delete this category by the given ID. ' We need to send a DELETE request like this: ' DELETE /api/v3/category/5840ff0975ac428ebf7838359e47737f Dim sbUrl As Chilkat.StringBuilder Set sbUrl = Chilkat.NewStringBuilder success = sbUrl.Append("https://my-shopware-6-shop.de/api/v3/category/") success = sbUrl.Append(categoryId) ' If successful (204 response code), then the jsonStr will be empty. ' Otherwise it will be a JSON error message. jsonStr = http.QuickDeleteStr(sbUrl.GetAsString()) If (http.LastMethodSuccess = False) Then Debug.Print http.LastErrorText Exit Sub End If ' A 204 status code indicates success. respStatusCode = http.LastStatus Debug.Print "Response status code for DELETE: "; respStatusCode ' This will be non-empty if an error occurred. Debug.Print jsonStr |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.