From a8bb5435dfb4487b637cf0bedf5ae8684adc0cac Mon Sep 17 00:00:00 2001 From: Nicolas MELONI Date: Thu, 12 Sep 2024 11:28:45 +0200 Subject: [PATCH] don't crash import on asset error --- .../ProductAttribute/AssetAttributeProcessor.php | 15 +++++++++++++-- 1 file changed, 13 insertions(+), 2 deletions(-) diff --git a/src/Processor/ProductAttribute/AssetAttributeProcessor.php b/src/Processor/ProductAttribute/AssetAttributeProcessor.php index c4aa1083..0aa33e06 100644 --- a/src/Processor/ProductAttribute/AssetAttributeProcessor.php +++ b/src/Processor/ProductAttribute/AssetAttributeProcessor.php @@ -5,6 +5,7 @@ namespace Synolia\SyliusAkeneoPlugin\Processor\ProductAttribute; use Akeneo\Pim\ApiClient\AkeneoPimClientInterface; +use Akeneo\Pim\ApiClient\Exception\RuntimeException; use Psr\Log\LoggerInterface; use Sylius\Component\Attribute\Model\AttributeInterface; use Sylius\Component\Core\Model\ProductInterface; @@ -128,8 +129,18 @@ public function process(string $attributeCode, array $context = []): void foreach ($context['data'] as $assetCodes) { foreach ($assetCodes['data'] as $assetCode) { - $assetResource = $this->akeneoPimClient->getAssetManagerApi()->get($attributeCode, $assetCode); - $this->handleAssetByFamilyResource($context['model'], $attributeCode, $assetResource); + try { + $assetResource = $this->akeneoPimClient->getAssetManagerApi()->get($attributeCode, $assetCode); + $this->handleAssetByFamilyResource($context['model'], $attributeCode, $assetResource); + } catch (RuntimeException $runtimeException) { + $this->logger->error('Error processing asset', [ + 'product' => $context['model']->getCode(), + 'asset_code' => $assetCode, + 'exception_code' => $runtimeException->getCode(), + 'exception_message' => $runtimeException->getMessage(), + 'exception_trace' => $runtimeException->getTraceAsString(), + ]); + } } } }