GetProductIdsBySourceItemIds.php 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. declare(strict_types=1);
  7. namespace Magento\InventoryIndexer\Model\ResourceModel;
  8. use Magento\Framework\App\ResourceConnection;
  9. use Magento\Inventory\Model\ResourceModel\SourceItem;
  10. use Magento\InventoryApi\Api\Data\SourceItemInterface;
  11. /**
  12. * Provides product ids related to specified source items ids.
  13. */
  14. class GetProductIdsBySourceItemIds
  15. {
  16. /**
  17. * @var ResourceConnection
  18. */
  19. private $resource;
  20. /**
  21. * @var string
  22. */
  23. private $productTableName;
  24. /**
  25. * @param ResourceConnection $resource
  26. * @param string $productTableName
  27. */
  28. public function __construct(
  29. ResourceConnection $resource,
  30. string $productTableName
  31. ) {
  32. $this->resource = $resource;
  33. $this->productTableName = $productTableName;
  34. }
  35. /**
  36. * Get product ids related to specified source items.
  37. *
  38. * @param array $sourceItemIds
  39. * @return array
  40. */
  41. public function execute(array $sourceItemIds): array
  42. {
  43. $connection = $this->resource->getConnection();
  44. $select = $connection->select()
  45. ->from(
  46. ['source_item' => $this->resource->getTableName(SourceItem::TABLE_NAME_SOURCE_ITEM)],
  47. []
  48. )->where(
  49. 'source_item.' . SourceItem::ID_FIELD_NAME . ' IN (?)',
  50. $sourceItemIds
  51. )->join(
  52. ['product' => $this->resource->getTableName($this->productTableName)],
  53. 'source_item.' . SourceItemInterface::SKU . ' = product.sku',
  54. ['product.entity_id']
  55. )->distinct();
  56. return $connection->fetchCol($select);
  57. }
  58. }