1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- declare(strict_types=1);
- namespace Magento\InventoryReservations\Model\ResourceModel;
- use Magento\Framework\App\ResourceConnection;
- use Magento\InventoryReservationsApi\Model\ReservationInterface;
- use Magento\InventoryReservationsApi\Model\CleanupReservationsInterface;
- /**
- * @inheritdoc
- */
- class CleanupReservations implements CleanupReservationsInterface
- {
- /**
- * @var ResourceConnection
- */
- private $resource;
- /**
- * @var int
- */
- private $groupConcatMaxLen;
- /**
- * @param ResourceConnection $resource
- * @param int $groupConcatMaxLen
- */
- public function __construct(
- ResourceConnection $resource,
- int $groupConcatMaxLen
- ) {
- $this->resource = $resource;
- $this->groupConcatMaxLen = $groupConcatMaxLen;
- }
- /**
- * @inheritdoc
- */
- public function execute(): void
- {
- $connection = $this->resource->getConnection();
- $reservationTable = $this->resource->getTableName('inventory_reservation');
- $select = $connection->select()
- ->from(
- $reservationTable,
- ['GROUP_CONCAT(' . ReservationInterface::RESERVATION_ID . ')']
- )
- ->group([ReservationInterface::STOCK_ID, ReservationInterface::SKU])
- ->having('SUM(' . ReservationInterface::QUANTITY . ') = 0');
- $connection->query('SET group_concat_max_len = ' . $this->groupConcatMaxLen);
- $groupedReservationIds = implode(',', $connection->fetchCol($select));
- $condition = [ReservationInterface::RESERVATION_ID . ' IN (?)' => explode(',', $groupedReservationIds)];
- $connection->delete($reservationTable, $condition);
- }
- }
|