GetSourceCodesBySkus.php 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  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\Inventory\Model\ResourceModel;
  8. use Magento\Framework\App\ResourceConnection;
  9. /**
  10. * Retrieve a list of source codes by a selection of SKUs
  11. */
  12. class GetSourceCodesBySkus
  13. {
  14. /**
  15. * @var ResourceConnection
  16. */
  17. private $resourceConnection;
  18. /**
  19. * @param ResourceConnection $resourceConnection
  20. */
  21. public function __construct(
  22. ResourceConnection $resourceConnection
  23. ) {
  24. $this->resourceConnection = $resourceConnection;
  25. }
  26. /**
  27. * @param array $skus
  28. * @return string[]
  29. */
  30. public function execute(array $skus): array
  31. {
  32. $tableName = $this->resourceConnection->getTableName(SourceItem::TABLE_NAME_SOURCE_ITEM);
  33. $connection = $this->resourceConnection->getConnection();
  34. $qry = $connection
  35. ->select()
  36. ->distinct()
  37. ->from($tableName, 'source_code')
  38. ->where('sku IN (?)', $skus);
  39. return $connection->fetchCol($qry);
  40. }
  41. }