mirror of
https://github.com/OpenXE-org/OpenXE.git
synced 2025-01-12 14:51:14 +01:00
149 lines
4.0 KiB
PHP
149 lines
4.0 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace Xentral\Modules\Shopware6\Client;
|
|
|
|
use Xentral\Components\HttpClient\HttpClient;
|
|
use Xentral\Components\HttpClient\HttpClientInterface;
|
|
use Xentral\Components\HttpClient\Request\ClientRequest;
|
|
use Xentral\Modules\Shopware6\Data\PriceData;
|
|
|
|
final class Shopware6Client
|
|
{
|
|
|
|
/** @var HttpClient */
|
|
protected $client;
|
|
/** @var string */
|
|
protected $token;
|
|
/** @var string */
|
|
protected $userName;
|
|
/** @var string */
|
|
protected $password;
|
|
/** @var string */
|
|
protected $url;
|
|
|
|
/** @var array */
|
|
protected $knownGroupRuleIds = [];
|
|
|
|
|
|
/**
|
|
* Shopware6Client constructor.
|
|
*
|
|
* @param HttpClientInterface $client
|
|
*/
|
|
public function __construct(HttpClientInterface $client)
|
|
{
|
|
$this->client = $client;
|
|
}
|
|
|
|
public function setCredentials(string $userName, string $password, string $url): void
|
|
{
|
|
$this->userName = $userName;
|
|
$this->password = $password;
|
|
$this->url = $url;
|
|
}
|
|
|
|
public function getGroupRuleId(string $groupName): string
|
|
{
|
|
if (array_key_exists($groupName, $this->knownGroupRuleIds)) {
|
|
return $this->knownGroupRuleIds[$groupName];
|
|
}
|
|
|
|
$groupRuleData = $this->request(
|
|
'GET',
|
|
"rule?filter[rule.name]={$groupName}&sort=priority"
|
|
);
|
|
|
|
$groupRuleId = '';
|
|
if (!empty($groupRuleData['data'][0]['id'])) {
|
|
$groupRuleId = $groupRuleData['data'][0]['id'];
|
|
}
|
|
$this->knownGroupRuleIds[$groupName] = $groupRuleId;
|
|
|
|
return $groupRuleId;
|
|
}
|
|
|
|
protected function request(string $method, string $endpoint, array $body = [], array $headerInformation = [])
|
|
{
|
|
$this->ensureAuthentication();
|
|
$headerInformation['Content-Type'] = 'application/json';
|
|
$headerInformation['Accept'] = 'application/json';
|
|
$headerInformation['Authorization'] = 'Bearer ' . $this->token;
|
|
|
|
$request = new ClientRequest(
|
|
$method,
|
|
$this->url . 'v2/' . $endpoint,
|
|
$headerInformation,
|
|
empty($body) ? null : json_encode($body)
|
|
);
|
|
|
|
$response = $this->client->sendRequest($request);
|
|
|
|
return json_decode($response->getBody()->getContents(), true);
|
|
}
|
|
|
|
protected function ensureAuthentication(): void
|
|
{
|
|
if ($this->token === null) {
|
|
$this->getAuthenticationToken();
|
|
}
|
|
}
|
|
|
|
protected function getAuthenticationToken(): void
|
|
{
|
|
$headerInformation = [
|
|
'Accept' => 'application/json',
|
|
'Content-Type' => 'application/json',
|
|
];
|
|
$body = [
|
|
'username' => $this->userName,
|
|
'password' => $this->password,
|
|
'grant_type' => 'password',
|
|
'scopes' => 'write',
|
|
'client_id' => 'administration',
|
|
];
|
|
$request = new ClientRequest(
|
|
'POST',
|
|
$this->url . 'oauth/token',
|
|
$headerInformation,
|
|
json_encode($body)
|
|
);
|
|
|
|
$response = $this->client->sendRequest($request);
|
|
$this->token = json_decode($response->getBody()->getContents(), true)['access_token'];
|
|
}
|
|
|
|
public function saveBulkPrice(string $productId, string $ruleId, string $currencyId, PriceData $priceData)
|
|
{
|
|
$data = [
|
|
'productId' => $productId,
|
|
'quantityStart' => $priceData->getStartingQuantity(),
|
|
'ruleId' => $ruleId,
|
|
'price' => [
|
|
[
|
|
'currencyId' => $currencyId,
|
|
'gross' => $priceData->getGross(),
|
|
'net' => $priceData->getNet(),
|
|
'linked' => true,
|
|
],
|
|
],
|
|
];
|
|
|
|
return $this->request(
|
|
'POST',
|
|
'product-price?_response=true',
|
|
$data
|
|
);
|
|
}
|
|
|
|
public function getAllSalesChannels()
|
|
{
|
|
return $this->request(
|
|
'GET',
|
|
'sales-channel'
|
|
);
|
|
}
|
|
|
|
}
|