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
(Tcl) Shopware 6 - Delete CategorySee more Shopware 6 ExamplesDelete a category by name.
load ./chilkat.dll # This example assumes the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. set http [new_CkHttp] # 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 set json [new_CkJsonObject] CkJsonObject_UpdateString $json "filter[0].type" "equals" CkJsonObject_UpdateString $json "filter[0].field" "name" CkJsonObject_UpdateString $json "filter[0].value" "Test123" CkJsonObject_UpdateString $json "includes.category[0]" "id" CkJsonObject_UpdateString $json "includes.category[1]" "name" # Load the access token previously obtained in Shopware 6 OAuth2 Client Credentials set jsonToken [new_CkJsonObject] CkJsonObject_LoadFile $jsonToken "qa_data/tokens/shopware6.json" # This causes the "Authorization: Bearer <access_token>" header to be added. CkHttp_put_AuthToken $http [CkJsonObject_stringOf $jsonToken "access_token"] # Note: If you get a 401 response status code, then fetch a new access token and retry. # resp is a CkHttpResponse set resp [CkHttp_PostJson3 $http "https://my-shopware-6-shop.de/api/v3/search/category" "application/json" $json] if {[CkHttp_get_LastMethodSuccess $http] == 0} then { puts [CkHttp_lastErrorText $http] delete_CkHttp $http delete_CkJsonObject $json delete_CkJsonObject $jsonToken exit } set sbResponseBody [new_CkStringBuilder] CkHttpResponse_GetBodySb $resp $sbResponseBody set jResp [new_CkJsonObject] CkJsonObject_LoadSb $jResp $sbResponseBody CkJsonObject_put_EmitCompact $jResp 0 puts "Response Body:" puts [CkJsonObject_emit $jResp] # If we get a 401 response, it may be that our access token expired and we need to fetch a new one. set respStatusCode [CkHttpResponse_get_StatusCode $resp] puts "Response Status Code = $respStatusCode" if {$respStatusCode >= 400} then { puts "Response Header:" puts [CkHttpResponse_header $resp] puts "Failed." delete_CkHttpResponse $resp delete_CkHttp $http delete_CkJsonObject $json delete_CkJsonObject $jsonToken delete_CkStringBuilder $sbResponseBody delete_CkJsonObject $jResp exit } delete_CkHttpResponse $resp # 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": [ # ] # } set numSearchResults [CkJsonObject_SizeOfArray $jResp "data"] if {$numSearchResults != 1} then { puts "numSearchResults = $numSearchResults" puts "Did not find the category, or unexpectedly found more than one with the same name." delete_CkHttp $http delete_CkJsonObject $json delete_CkJsonObject $jsonToken delete_CkStringBuilder $sbResponseBody delete_CkJsonObject $jResp exit } set categoryId [CkJsonObject_stringOf $jResp "data[0].id"] puts "Category ID = $categoryId" # ----------------------------------------------------------------------------------------------- # Delete this category by the given ID. # We need to send a DELETE request like this: # DELETE /api/v3/category/5840ff0975ac428ebf7838359e47737f set sbUrl [new_CkStringBuilder] CkStringBuilder_Append $sbUrl "https://my-shopware-6-shop.de/api/v3/category/" CkStringBuilder_Append $sbUrl $categoryId # If successful (204 response code), then the jsonStr will be empty. # Otherwise it will be a JSON error message. set jsonStr [CkHttp_quickDeleteStr $http [CkStringBuilder_getAsString $sbUrl]] if {[CkHttp_get_LastMethodSuccess $http] == 0} then { puts [CkHttp_lastErrorText $http] delete_CkHttp $http delete_CkJsonObject $json delete_CkJsonObject $jsonToken delete_CkStringBuilder $sbResponseBody delete_CkJsonObject $jResp delete_CkStringBuilder $sbUrl exit } # A 204 status code indicates success. set respStatusCode [CkHttp_get_LastStatus $http] puts "Response status code for DELETE: $respStatusCode" # This will be non-empty if an error occurred. puts "$jsonStr" delete_CkHttp $http delete_CkJsonObject $json delete_CkJsonObject $jsonToken delete_CkStringBuilder $sbResponseBody delete_CkJsonObject $jResp delete_CkStringBuilder $sbUrl |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.