Visual FoxPro
Visual FoxPro
Shopware 6 - Create Product
See more Shopware 6 Examples
Create a new product.Chilkat Visual FoxPro Downloads
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJson
LOCAL loJsonToken
LOCAL loResp
LOCAL loSbResponseBody
LOCAL loJResp
LOCAL lnRespStatusCode
lnSuccess = 0
* This example assumes the Chilkat API to have been previously unlocked.
* See Global Unlock Sample for sample code.
loHttp = CreateObject('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"
loJson = CreateObject('Chilkat.JsonObject')
loJson.UpdateString("name","Test123")
loJson.UpdateString("productNumber","XYZ-1234")
loJson.UpdateInt("stock",10)
loJson.UpdateString("price[0].currencyId","b7d2554b0ce847cd82f3ac9bd1c0dfca")
loJson.UpdateInt("price[0].gross",15)
loJson.UpdateInt("price[0].net",10)
loJson.UpdateBool("price[0].linked",0)
loJson.UpdateString("tax.name","test")
loJson.UpdateInt("tax.taxRate",15)
* Load the access token previously obtained in Shopware 6 OAuth2 Client Credentials
loJsonToken = CreateObject('Chilkat.JsonObject')
loJsonToken.LoadFile("qa_data/tokens/shopware6.json")
* This causes the "Authorization: Bearer <access_token>" header to be added.
loHttp.AuthToken = loJsonToken.StringOf("access_token")
loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpJson("POST","https://my-shopware-6-shop.de/api/v3/product",loJson,"application/json",loResp)
IF (lnSuccess = 0) THEN
? loHttp.LastErrorText
RELEASE loHttp
RELEASE loJson
RELEASE loJsonToken
RELEASE loResp
CANCEL
ENDIF
loSbResponseBody = CreateObject('Chilkat.StringBuilder')
loResp.GetBodySb(loSbResponseBody)
loJResp = CreateObject('Chilkat.JsonObject')
loJResp.LoadSb(loSbResponseBody)
loJResp.EmitCompact = 0
* A successful response is a 204 response status code with an empty response body.
? "Response Body:"
? loJResp.Emit()
* If we get a 401 response, it may be that our access token expired and we need to fetch a new one.
lnRespStatusCode = loResp.StatusCode
? "Response Status Code = " + STR(lnRespStatusCode)
IF (lnRespStatusCode >= 400) THEN
? "Response Header:"
? loResp.Header
? "Failed."
RELEASE loHttp
RELEASE loJson
RELEASE loJsonToken
RELEASE loResp
RELEASE loSbResponseBody
RELEASE loJResp
CANCEL
ENDIF
RELEASE loHttp
RELEASE loJson
RELEASE loJsonToken
RELEASE loResp
RELEASE loSbResponseBody
RELEASE loJResp