(JavaScript) Shopware 6 - Create Product
Create a new product.For more information, see https://docs.shopware.com/en/shopware-platform-dev-en/admin-api-guide/writing-entities#creating-entities
var success = false;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
var http = new CkHttp();
// 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"
var json = new CkJsonObject();
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
var jsonToken = new CkJsonObject();
jsonToken.LoadFile("qa_data/tokens/shopware6.json");
// This causes the "Authorization: Bearer <access_token>" header to be added.
http.AuthToken = jsonToken.StringOf("access_token");
var resp = new CkHttpResponse();
success = http.HttpJson("POST","https://my-shopware-6-shop.de/api/v3/product",json,"application/json",resp);
if (success == false) {
console.log(http.LastErrorText);
return;
}
var sbResponseBody = new CkStringBuilder();
resp.GetBodySb(sbResponseBody);
var jResp = new CkJsonObject();
jResp.LoadSb(sbResponseBody);
jResp.EmitCompact = false;
// A successful response is a 204 response status code with an empty response body.
console.log("Response Body:");
console.log(jResp.Emit());
// If we get a 401 response, it may be that our access token expired and we need to fetch a new one.
var respStatusCode = resp.StatusCode;
console.log("Response Status Code = " + respStatusCode);
if (respStatusCode >= 400) {
console.log("Response Header:");
console.log(resp.Header);
console.log("Failed.");
return;
}
|