function DatabaseQueue::delayItem
Delay an item so it runs in the future.
Parameters
object $item: The item returned by \Drupal\Core\Queue\QueueInterface::claimItem().
int $delay: A delay before the item's lock should expire (in seconds). Relative to the current time, not the item's current expiry.
Return value
bool TRUE if the item has been updated, FALSE otherwise.
Overrides DelayableQueueInterface::delayItem
File
- 
              core/lib/ Drupal/ Core/ Queue/ DatabaseQueue.php, line 178 
Class
- DatabaseQueue
- Default queue implementation.
Namespace
Drupal\Core\QueueCode
public function delayItem($item, int $delay) {
  // Only allow a positive delay interval.
  if ($delay < 0) {
    throw new \InvalidArgumentException('$delay must be non-negative');
  }
  try {
    // Add the delay relative to the current time.
    $expire = \Drupal::time()->getCurrentTime() + $delay;
    // Update the expiry time of this item.
    $update = $this->connection
      ->update(static::TABLE_NAME)
      ->fields([
      'expire' => $expire,
    ])
      ->condition('item_id', $item->item_id);
    return (bool) $update->execute();
  } catch (\Exception $e) {
    $this->catchException($e);
    // If the table doesn't exist we should consider the item nonexistent.
    return TRUE;
  }
}Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.
