storage = $storage; $this->lockBackend = $lock_backend; $this->currentUser = $current_user; $this->requestStack = $request_stack; $this->expire = $expire; } /** * Retrieves a value from this PrivateTempStore for a given key. * * @param string $key * The key of the data to retrieve. * * @return mixed * The data associated with the key, or NULL if the key does not exist. */ public function get($key) { $key = $this->createKey($key); if (($object = $this->storage->get($key)) && ($object->owner == $this->getOwner())) { return $object->data; } } /** * Stores a particular key/value pair in this PrivateTempStore. * * @param string $key * The key of the data to store. * @param mixed $value * The data to store. * * @throws \Drupal\Core\TempStore\TempStoreException * Thrown when a lock for the backend storage could not be acquired. */ public function set($key, $value) { if ($this->currentUser->isAnonymous()) { $session = $this->requestStack->getSession(); if (!$session->has('core.tempstore.private.owner')) { $session->set('core.tempstore.private.owner', Crypt::randomBytesBase64()); } } $key = $this->createKey($key); if (!$this->lockBackend->acquire($key)) { $this->lockBackend->wait($key); if (!$this->lockBackend->acquire($key)) { throw new TempStoreException("Couldn't acquire lock to update item '$key' in '{$this->storage->getCollectionName()}' temporary storage."); } } $value = (object) [ 'owner' => $this->getOwner(), 'data' => $value, 'updated' => (int) $this->requestStack->getMainRequest()->server->get('REQUEST_TIME'), ]; $this->storage->setWithExpire($key, $value, $this->expire); $this->lockBackend->release($key); } /** * Returns the metadata associated with a particular key/value pair. * * @param string $key * The key of the data to store. * * @return \Drupal\Core\TempStore\Lock|null * An object with the owner and updated time if the key has a value, or * NULL otherwise. */ public function getMetadata($key) { $key = $this->createKey($key); // Fetch the key/value pair and its metadata. $object = $this->storage->get($key); if ($object) { // Don't keep the data itself in memory. unset($object->data); return new Lock($object->owner, $object->updated); } } /** * Deletes data from the store for a given key and releases the lock on it. * * @param string $key * The key of the data to delete. * * @return bool * TRUE if the object was deleted or does not exist, FALSE if it exists but * is not owned by $this->owner. * * @throws \Drupal\Core\TempStore\TempStoreException * Thrown when a lock for the backend storage could not be acquired. */ public function delete($key) { $key = $this->createKey($key); if (!$object = $this->storage->get($key)) { return TRUE; } elseif ($object->owner != $this->getOwner()) { return FALSE; } if (!$this->lockBackend->acquire($key)) { $this->lockBackend->wait($key); if (!$this->lockBackend->acquire($key)) { throw new TempStoreException("Couldn't acquire lock to delete item '$key' from '{$this->storage->getCollectionName()}' temporary storage."); } } $this->storage->delete($key); $this->lockBackend->release($key); return TRUE; } /** * Ensures that the key is unique for a user. * * @param string $key * The key. * * @return string * The unique key for the user. */ protected function createKey($key) { return $this->getOwner() . ':' . $key; } /** * Gets the current owner based on the current user or the session ID. * * @return string * The owner. */ protected function getOwner() { $owner = $this->currentUser->id(); if ($this->currentUser->isAnonymous()) { // Check to see if an owner key exists in the session. $session = $this->requestStack->getSession(); $owner = $session->get('core.tempstore.private.owner'); } return $owner; } }