public function SmsProcessor::processItem in SMS Framework 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
- src/
Plugin/ QueueWorker/ SmsProcessor.php, line 73
Class
- SmsProcessor
- Transmits SMS messages.
Namespace
Drupal\sms\Plugin\QueueWorkerCode
public function processItem($data) {
if (isset($data['id'])) {
$id = $data['id'];
/** @var \Drupal\sms\Entity\SmsMessageInterface $sms_message */
if ($sms_message = $this->smsMessageStorage
->load($id)) {
switch ($sms_message
->getDirection()) {
case Direction::INCOMING:
$this->smsProvider
->incoming($sms_message);
break;
case Direction::OUTGOING:
$this->smsProvider
->send($sms_message);
break;
}
$duration = NULL;
if ($gateway = $sms_message
->getGateway()) {
$duration = $gateway
->getRetentionDuration($sms_message
->getDirection());
}
// Clean up SMS message now if retention is set to delete immediately.
if ($duration === 0) {
$sms_message
->delete();
}
else {
$sms_message
->setProcessedTime(REQUEST_TIME)
->setQueued(FALSE)
->save();
}
}
}
}