public function StockLevelUpdater::processItem in Commerce Stock 8
Works on a single queue item.
Parameters
mixed $data: The data that was passed to \Drupal\Core\Queue\QueueInterface::createItem() when the item was queued.
Throws
\Drupal\Core\Queue\RequeueException Processing is not yet finished. This will allow another process to claim the item immediately.
\Exception A QueueWorker plugin may throw an exception to indicate there was a problem. The cron process will log the exception, and leave the item in the queue to be processed again later.
\Drupal\Core\Queue\SuspendQueueException More specifically, a SuspendQueueException should be thrown when a QueueWorker plugin is aware that the problem will affect all subsequent workers of its queue. For example, a callback that makes HTTP requests may find that the remote server is not responding. The cron process will behave as with a normal Exception, and in addition will not attempt to process further items from the current item's queue during the current cron run.
Overrides QueueWorkerInterface::processItem
See also
\Drupal\Core\Cron::processQueues()
File
- modules/
local_storage/ src/ Plugin/ QueueWorker/ StockLevelUpdater.php, line 23
Class
- StockLevelUpdater
- Commerce Stock Local location level update worker.
Namespace
Drupal\commerce_stock_local\Plugin\QueueWorkerCode
public function processItem($data) {
$storage = \Drupal::entityTypeManager()
->getStorage($data['entity_type']);
$entity = $storage
->load($data['entity_id']);
if (!$entity) {
return;
}
// Load the Stockupdate Service.
$service = \Drupal::service('commerce_stock.local_stock_service');
/** @var \Drupal\commerce_stock_local\LocalStockUpdater $updater */
$updater = $service
->getStockUpdater();
/** @var \Drupal\commerce_stock_local\StockLocationStorage $locationStorage */
$locationStorage = \Drupal::entityTypeManager()
->getStorage('commerce_stock_location');
$locations = $locationStorage
->loadEnabled($entity);
foreach ($locations as $location) {
$updater
->updateLocationStockLevel($location
->getId(), $entity);
}
$entity
->save();
}