<?php declare(strict_types=1);
namespace GlobusSW6\Subscriber\Psa;
use Shopware\Core\Content\Product\ProductCollection;
use Shopware\Core\Framework\Api\Context\SalesChannelApiSource;
use Shopware\Core\Framework\DataAbstractionLayer\Event\EntitySearchResultLoadedEvent;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use GlobusSW6\Service\PsaApi\PsaApiService;
use Psr\Log\LoggerInterface;
use Shopware\Storefront\Page\Product\ProductPageLoadedEvent;
use GlobusSW6\Service\IaneoBusinessExtension;
class ProductPsaExtensionSubscriber implements EventSubscriberInterface
{
/** @var LoggerInterface */
private $logger;
/** @var IaneoBusinessExtension */
private $ianeoBusinessExtension;
/** @var PsaApiService */
private $psaApiService;
/**
* ProductPsaExtensionSubscriber constructor.
* @param LoggerInterface $logger
* @param IaneoBusinessExtension $ianeoBusinessExtension
* @param PsaApiService $psaApiService
*/
public function __construct(LoggerInterface $logger, IaneoBusinessExtension $ianeoBusinessExtension, PsaApiService $psaApiService)
{
$this->logger = $logger;
$this->ianeoBusinessExtension = $ianeoBusinessExtension;
$this->psaApiService = $psaApiService;
}
public static function getSubscribedEvents(): array
{
return [
'product.search.result.loaded' => 'onProductLoaded'
];
}
public function onProductLoaded(EntitySearchResultLoadedEvent $event)
{
/** @var ProductCollection $products */
$products = $event->getResult()->getEntities();
if ($products === null) {
return;
}
if ($event->getContext()->getSource() instanceOf SalesChannelApiSource)
{
foreach ($products as $product) {
try {
$psa = $this->psaApiService->getPsaByProductId($product->getId(), $event->getContext());
if($psa) {
$this->ianeoBusinessExtension->addSingleAttributeToProduct($product, $psa, 'psa');
}
} catch(\Exception $exception) {
$this->logger->error(__CLASS__ . ":" . __FUNCTION__ . ":" . __LINE__ . ":\$exception->getMessage(): " . $exception->getMessage());
}
}
}
}
}