Sample code for 30+ languages & platforms
PHP Extension

Shopware 6 - Create Product

See more Shopware 6 Examples

Create a new product.

Chilkat PHP Extension Downloads

PHP Extension
<?php

include("chilkat.php");

$success = false;

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

$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"
$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
$jsonToken = new CkJsonObject();
$jsonToken->LoadFile('qa_data/tokens/shopware6.json');

// This causes the "Authorization: Bearer <access_token>" header to be added.
$http->put_AuthToken($jsonToken->stringOf('access_token'));

$resp = new CkHttpResponse();
$success = $http->HttpJson('POST','https://my-shopware-6-shop.de/api/v3/product',$json,'application/json',$resp);
if ($success == false) {
    print $http->lastErrorText() . "\n";
    exit;
}

$sbResponseBody = new CkStringBuilder();
$resp->GetBodySb($sbResponseBody);
$jResp = new CkJsonObject();
$jResp->LoadSb($sbResponseBody);
$jResp->put_EmitCompact(false);

// A successful response is a 204 response status code with an empty response body.
print 'Response Body:' . "\n";
print $jResp->emit() . "\n";

// If we get a 401 response, it may be that our access token expired and we need to fetch a new one.
$respStatusCode = $resp->get_StatusCode();
print 'Response Status Code = ' . $respStatusCode . "\n";
if ($respStatusCode >= 400) {
    print 'Response Header:' . "\n";
    print $resp->header() . "\n";
    print 'Failed.' . "\n";
    exit;
}


?>