ExportStorageManager.php

Same filename and directory in other branches
  1. 9 core/lib/Drupal/Core/Config/ExportStorageManager.php
  2. 8.9.x core/lib/Drupal/Core/Config/ExportStorageManager.php
  3. 10 core/lib/Drupal/Core/Config/ExportStorageManager.php

Namespace

Drupal\Core\Config

File

core/lib/Drupal/Core/Config/ExportStorageManager.php

View source
<?php

namespace Drupal\Core\Config;

use Drupal\Core\Database\Connection;
use Drupal\Core\Lock\LockBackendInterface;
use Symfony\Contracts\EventDispatcher\EventDispatcherInterface;

/**
 * The export storage manager dispatches an event for the export storage.
 *
 * This class is not meant to be extended and is final to make sure the
 * constructor and the getStorage method are both changed when this pattern is
 * used in other circumstances.
 */
final class ExportStorageManager implements StorageManagerInterface {
    use StorageCopyTrait;
    
    /**
     * The name used to identify the lock.
     */
    const LOCK_NAME = 'config_storage_export_manager';
    
    /**
     * The active configuration storage.
     *
     * @var \Drupal\Core\Config\StorageInterface
     */
    protected $active;
    
    /**
     * The database storage.
     *
     * @var \Drupal\Core\Config\DatabaseStorage
     */
    protected $storage;
    
    /**
     * The event dispatcher.
     *
     * @var \Symfony\Contracts\EventDispatcher\EventDispatcherInterface
     */
    protected $eventDispatcher;
    
    /**
     * The used lock backend instance.
     *
     * @var \Drupal\Core\Lock\LockBackendInterface
     */
    protected $lock;
    
    /**
     * ExportStorageManager constructor.
     *
     * @param \Drupal\Core\Config\StorageInterface $active
     *   The active config storage to prime the export storage.
     * @param \Drupal\Core\Database\Connection $connection
     *   The database connection.
     * @param \Symfony\Contracts\EventDispatcher\EventDispatcherInterface $event_dispatcher
     *   The event dispatcher.
     * @param \Drupal\Core\Lock\LockBackendInterface $lock
     *   The used lock backend instance.
     */
    public function __construct(StorageInterface $active, Connection $connection, EventDispatcherInterface $event_dispatcher, LockBackendInterface $lock) {
        $this->active = $active;
        $this->eventDispatcher = $event_dispatcher;
        $this->lock = $lock;
        // The point of this service is to provide the storage and dispatch the
        // event when needed, so the storage itself can not be a service.
        $this->storage = new DatabaseStorage($connection, 'config_export');
    }
    
    /**
     * {@inheritdoc}
     */
    public function getStorage() {
        // Acquire a lock for the request to assert that the storage does not change
        // when a concurrent request transforms the storage.
        if (!$this->lock
            ->acquire(self::LOCK_NAME)) {
            $this->lock
                ->wait(self::LOCK_NAME);
            if (!$this->lock
                ->acquire(self::LOCK_NAME)) {
                throw new StorageTransformerException("Cannot acquire config export transformer lock.");
            }
        }
        self::replaceStorageContents($this->active, $this->storage);
        $this->eventDispatcher
            ->dispatch(new StorageTransformEvent($this->storage), ConfigEvents::STORAGE_TRANSFORM_EXPORT);
        return new ReadOnlyStorage($this->storage);
    }

}

Classes

Title Deprecated Summary
ExportStorageManager The export storage manager dispatches an event for the export storage.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.