VB.NET
VB.NET
Shopware 6 - Create Product
See more Shopware 6 Examples
Create a new product.Chilkat VB.NET Downloads
Dim success As Boolean = False
' This example assumes the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.
Dim http As New Chilkat.Http
' Sends the following POST
' POST /api/v3/product/
' {
' "name" : "Test123",
' "productNumber" : "random",
' "stock" : 10,
' "price" : [
' {
' "currencyId" : "b7d2554b0ce847cd82f3ac9bd1c0dfca",
' "gross": 15,
' "net": 10,
' "linked" : false
' }
' ],
' "tax" : {
' "name": "test",
' "taxRate": 15
' }
' }
' Use this online tool to generate code from sample JSON:
' Generate Code to Create JSON
' Create a product named "Test123"
Dim json As New Chilkat.JsonObject
json.UpdateString("name","Test123")
json.UpdateString("productNumber","XYZ-1234")
json.UpdateInt("stock",10)
json.UpdateString("price[0].currencyId","b7d2554b0ce847cd82f3ac9bd1c0dfca")
json.UpdateInt("price[0].gross",15)
json.UpdateInt("price[0].net",10)
json.UpdateBool("price[0].linked",False)
json.UpdateString("tax.name","test")
json.UpdateInt("tax.taxRate",15)
' Load the access token previously obtained in Shopware 6 OAuth2 Client Credentials
Dim jsonToken As New Chilkat.JsonObject
jsonToken.LoadFile("qa_data/tokens/shopware6.json")
' This causes the "Authorization: Bearer <access_token>" header to be added.
http.AuthToken = jsonToken.StringOf("access_token")
Dim resp As New Chilkat.HttpResponse
success = http.HttpJson("POST","https://my-shopware-6-shop.de/api/v3/product",json,"application/json",resp)
If (success = False) Then
Debug.WriteLine(http.LastErrorText)
Exit Sub
End If
Dim sbResponseBody As New Chilkat.StringBuilder
resp.GetBodySb(sbResponseBody)
Dim jResp As New Chilkat.JsonObject
jResp.LoadSb(sbResponseBody)
jResp.EmitCompact = False
' A successful response is a 204 response status code with an empty response body.
Debug.WriteLine("Response Body:")
Debug.WriteLine(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 Integer = resp.StatusCode
Debug.WriteLine("Response Status Code = " & respStatusCode)
If (respStatusCode >= 400) Then
Debug.WriteLine("Response Header:")
Debug.WriteLine(resp.Header)
Debug.WriteLine("Failed.")
Exit Sub
End If