You are here

public function DatabaseStorage::doSetIfNotExists in Drupal 9

Saves a value for a given key if it does not exist yet.

This will be called by setIfNotExists() within a try block.

Parameters

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

mixed $value: The data to store.

Return value

bool TRUE if the data was set, FALSE if it already existed.

1 call to DatabaseStorage::doSetIfNotExists()
DatabaseStorage::setIfNotExists in core/lib/Drupal/Core/KeyValueStore/DatabaseStorage.php
Saves a value for a given key if it does not exist yet.

File

core/lib/Drupal/Core/KeyValueStore/DatabaseStorage.php, line 170

Class

DatabaseStorage
Defines a default key/value store implementation.

Namespace

Drupal\Core\KeyValueStore

Code

public function doSetIfNotExists($key, $value) {
  $result = $this->connection
    ->merge($this->table)
    ->insertFields([
    'collection' => $this->collection,
    'name' => $key,
    'value' => $this->serializer
      ->encode($value),
  ])
    ->condition('collection', $this->collection)
    ->condition('name', $key)
    ->execute();
  return $result == Merge::STATUS_INSERT;
}