Skip to content

Commit dbfd7fe

Browse files
BEG-143: Performance improvement and code refactoring #15
1 parent 6a9faad commit dbfd7fe

File tree

3 files changed

+20
-77
lines changed

3 files changed

+20
-77
lines changed

Helper/ProductIndexer.php

Lines changed: 0 additions & 51 deletions
This file was deleted.

Model/Indexer/Category/ProductIndexer.php

Lines changed: 9 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -9,9 +9,9 @@
99

1010
use Aligent\PrerenderIo\Api\PrerenderClientInterface;
1111
use Aligent\PrerenderIo\Helper\Config;
12-
use Aligent\PrerenderIo\Helper\ProductIndexer as ProductIndexerHelper;
1312
use Aligent\PrerenderIo\Model\Indexer\DataProvider\ProductCategories;
1413
use Aligent\PrerenderIo\Model\Url\GetUrlsForCategories;
14+
use Magento\ConfigurableProduct\Model\Product\Type\Configurable;
1515
use Magento\Framework\App\DeploymentConfig;
1616
use Magento\Framework\Exception\FileSystemException;
1717
use Magento\Framework\Exception\LocalizedException;
@@ -39,10 +39,8 @@ class ProductIndexer implements IndexerActionInterface, MviewActionInterface, Di
3939
private DeploymentConfig $eploymentConfig;
4040
/** @var Config */
4141
private Config $prerenderConfigHelper;
42-
/**
43-
* @var ProductIndexerHelper
44-
*/
45-
private ProductIndexerHelper $productIndexerHelper;
42+
/** @var Configurable */
43+
private Configurable $configurable;
4644
/** @var int|null */
4745
private ?int $batchSize;
4846

@@ -63,7 +61,7 @@ public function __construct(
6361
PrerenderClientInterface $prerenderClient,
6462
DeploymentConfig $deploymentConfig,
6563
Config $prerenderConfigHelper,
66-
ProductIndexerHelper $productIndexerHelper,
64+
Configurable $configurable,
6765
?int $batchSize = 1000
6866
) {
6967
$this->dimensionProvider = $dimensionProvider;
@@ -73,7 +71,7 @@ public function __construct(
7371
$this->deploymentConfig = $deploymentConfig;
7472
$this->batchSize = $batchSize;
7573
$this->prerenderConfigHelper = $prerenderConfigHelper;
76-
$this->productIndexerHelper = $this->productIndexerHelper;
74+
$this->configurable = $configurable;
7775
}
7876

7977
/**
@@ -151,13 +149,11 @@ public function executeByDimensions(array $dimensions, \Traversable $entityIds):
151149
}
152150

153151
$entityIds = iterator_to_array($entityIds);
152+
154153
// Include configurable product id(s) if the edited product is simple
155-
foreach ($entityIds as $entityId) {
156-
$parentEntityIds = $this->productIndexerHelper->getParentEntityId($entityId);
157-
if (!empty($parentEntityIds)) {
158-
$entityIds = array_merge($entityIds, $parentEntityIds);
159-
}
160-
}
154+
$parentIds = $this->configurable->getParentIdsByChild($entityIds);
155+
$entityIds = array_unique(array_merge($entityIds, $parentIds));
156+
161157
// get list of category ids for the products
162158
$categoryIds = $this->productCategoriesDataProvider->getCategoryIdsForProducts($entityIds, $storeId);
163159

Model/Indexer/Product/ProductIndexer.php

Lines changed: 11 additions & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -9,8 +9,8 @@
99

1010
use Aligent\PrerenderIo\Api\PrerenderClientInterface;
1111
use Aligent\PrerenderIo\Helper\Config;
12-
use Aligent\PrerenderIo\Helper\ProductIndexer as ProductIndexerHelper;
1312
use Aligent\PrerenderIo\Model\Url\GetUrlsForProducts;
13+
use Magento\ConfigurableProduct\Model\Product\Type\Configurable;
1414
use Magento\Framework\App\DeploymentConfig;
1515
use Magento\Framework\Exception\FileSystemException;
1616
use Magento\Framework\Exception\LocalizedException;
@@ -36,10 +36,8 @@ class ProductIndexer implements IndexerActionInterface, MviewActionInterface, Di
3636
private DeploymentConfig $eploymentConfig;
3737
/** @var Config */
3838
private Config $prerenderConfigHelper;
39-
/**
40-
* @var ProductIndexerHelper
41-
*/
42-
private ProductIndexerHelper $productIndexerHelper;
39+
/** @var Configurable */
40+
private Configurable $configurable;
4341
/** @var int|null */
4442
private ?int $batchSize;
4543

@@ -50,6 +48,8 @@ class ProductIndexer implements IndexerActionInterface, MviewActionInterface, Di
5048
* @param PrerenderClientInterface $prerenderClient
5149
* @param DeploymentConfig $deploymentConfig
5250
* @param Config $prerenderConfigHelper
51+
* @param Configurable $configurable
52+
*
5353
* @param int|null $batchSize
5454
*/
5555
public function __construct(
@@ -58,7 +58,7 @@ public function __construct(
5858
PrerenderClientInterface $prerenderClient,
5959
DeploymentConfig $deploymentConfig,
6060
Config $prerenderConfigHelper,
61-
ProductIndexerHelper $productIndexerHelper,
61+
Configurable $configurable,
6262
?int $batchSize = 1000
6363
) {
6464
$this->dimensionProvider = $dimensionProvider;
@@ -67,7 +67,7 @@ public function __construct(
6767
$this->deploymentConfig = $deploymentConfig;
6868
$this->batchSize = $batchSize;
6969
$this->prerenderConfigHelper = $prerenderConfigHelper;
70-
$this->productIndexerHelper = $productIndexerHelper;
70+
$this->configurable = $configurable;
7171
}
7272

7373
/**
@@ -145,13 +145,11 @@ public function executeByDimensions(array $dimensions, \Traversable $entityIds):
145145
}
146146

147147
$entityIds = iterator_to_array($entityIds);
148+
148149
// Include configurable product id(s) if the edited product is simple
149-
foreach ($entityIds as $entityId) {
150-
$parentEntityIds = $this->productIndexerHelper->getParentEntityId($entityId);
151-
if (!empty($parentEntityIds)) {
152-
$entityIds = array_merge($entityIds, $parentEntityIds);
153-
}
154-
}
150+
$parentIds = $this->configurable->getParentIdsByChild($entityIds);
151+
$entityIds = array_unique(array_merge($entityIds, $parentIds));
152+
155153
// get urls for the products
156154
$urls = $this->getUrlsForProducts->execute($entityIds, $storeId);
157155

0 commit comments

Comments
 (0)