You are here

function DatabaseStorageExpirable::setWithExpire in Service Container 7

Same name in this branch
  1. 7 src/KeyValueStore/DatabaseStorageExpirable.php \Drupal\service_container\KeyValueStore\DatabaseStorageExpirable::setWithExpire()
  2. 7 lib/Drupal/Core/KeyValueStore/DatabaseStorageExpirable.php \Drupal\Core\KeyValueStore\DatabaseStorageExpirable::setWithExpire()
Same name and namespace in other branches
  1. 7.2 lib/Drupal/Core/KeyValueStore/DatabaseStorageExpirable.php \Drupal\Core\KeyValueStore\DatabaseStorageExpirable::setWithExpire()

Saves a value for a given key with a time to live.

Parameters

string $key: The key of the data to store.

mixed $value: The data to store.

int $expire: The time to live for items, in seconds.

Overrides KeyValueStoreExpirableInterface::setWithExpire

1 call to DatabaseStorageExpirable::setWithExpire()
DatabaseStorageExpirable::setMultipleWithExpire in lib/Drupal/Core/KeyValueStore/DatabaseStorageExpirable.php
Saves an array of values with a time to live.
1 method overrides DatabaseStorageExpirable::setWithExpire()
DatabaseStorageExpirable::setWithExpire in src/KeyValueStore/DatabaseStorageExpirable.php
Saves a value for a given key with a time to live.

File

lib/Drupal/Core/KeyValueStore/DatabaseStorageExpirable.php, line 93
Contains \Drupal\Core\KeyValueStore\DatabaseStorageExpirable.

Class

DatabaseStorageExpirable
Defines a default key/value store implementation for expiring items.

Namespace

Drupal\Core\KeyValueStore

Code

function setWithExpire($key, $value, $expire) {

  // We are already writing to the table, so perform garbage collection at
  // the end of this request.
  $this->needsGarbageCollection = TRUE;
  $this->connection
    ->merge($this->table)
    ->keys(array(
    'name' => $key,
    'collection' => $this->collection,
  ))
    ->fields(array(
    'value' => $this->serializer
      ->encode($value),
    'expire' => REQUEST_TIME + $expire,
  ))
    ->execute();
}