BundleConfigImportValidate.php

Same filename in other branches
  1. 9 core/lib/Drupal/Core/Entity/Event/BundleConfigImportValidate.php
  2. 10 core/lib/Drupal/Core/Entity/Event/BundleConfigImportValidate.php
  3. 11.x core/lib/Drupal/Core/Entity/Event/BundleConfigImportValidate.php

Namespace

Drupal\Core\Entity\Event

File

core/lib/Drupal/Core/Entity/Event/BundleConfigImportValidate.php

View source
<?php

namespace Drupal\Core\Entity\Event;

use Drupal\Core\Config\ConfigImporterEvent;
use Drupal\Core\Config\ConfigImportValidateEventSubscriberBase;
use Drupal\Core\Config\ConfigManagerInterface;
use Drupal\Core\Config\Entity\ConfigEntityStorage;
use Drupal\Core\DependencyInjection\DeprecatedServicePropertyTrait;
use Drupal\Core\Entity\EntityManagerInterface;
use Drupal\Core\Entity\EntityTypeManagerInterface;

/**
 * Entity config importer validation event subscriber.
 */
class BundleConfigImportValidate extends ConfigImportValidateEventSubscriberBase {
    use DeprecatedServicePropertyTrait;
    
    /**
     * {@inheritdoc}
     */
    protected $deprecatedProperties = [
        'entityManager' => 'entity.manager',
    ];
    
    /**
     * The config manager.
     *
     * @var \Drupal\Core\Config\ConfigManagerInterface
     */
    protected $configManager;
    
    /**
     * The entity type manager service.
     *
     * @var \Drupal\Core\Entity\EntityTypeManagerInterface
     */
    protected $entityTypeManager;
    
    /**
     * Constructs the event subscriber.
     *
     * @param \Drupal\Core\Config\ConfigManagerInterface $config_manager
     *   The config manager.
     * @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
     *   The entity type manager service.
     */
    public function __construct(ConfigManagerInterface $config_manager, EntityTypeManagerInterface $entity_type_manager) {
        $this->configManager = $config_manager;
        if ($entity_type_manager instanceof EntityManagerInterface) {
            @trigger_error('Passing the entity.manager service to BundleConfigImportValidate::__construct() is deprecated in Drupal 8.7.0 and will be removed before Drupal 9.0.0. Pass the new dependencies instead. See https://www.drupal.org/node/2549139.', E_USER_DEPRECATED);
            $this->entityTypeManager = \Drupal::entityTypeManager();
        }
        else {
            $this->entityTypeManager = $entity_type_manager;
        }
    }
    
    /**
     * Ensures bundles that will be deleted are not in use.
     *
     * @param \Drupal\Core\Config\ConfigImporterEvent $event
     *   The config import event.
     */
    public function onConfigImporterValidate(ConfigImporterEvent $event) {
        foreach ($event->getChangelist('delete') as $config_name) {
            // Get the config entity type ID. This also ensure we are dealing with a
            // configuration entity.
            if ($entity_type_id = $this->configManager
                ->getEntityTypeIdByName($config_name)) {
                $entity_type = $this->entityTypeManager
                    ->getDefinition($entity_type_id);
                // Does this entity type define a bundle of another entity type.
                if ($bundle_of = $entity_type->getBundleOf()) {
                    // Work out if there are entities with this bundle.
                    $bundle_of_entity_type = $this->entityTypeManager
                        ->getDefinition($bundle_of);
                    $bundle_id = ConfigEntityStorage::getIDFromConfigName($config_name, $entity_type->getConfigPrefix());
                    $entity_query = $this->entityTypeManager
                        ->getStorage($bundle_of)
                        ->getQuery();
                    $entity_ids = $entity_query->condition($bundle_of_entity_type->getKey('bundle'), $bundle_id)
                        ->accessCheck(FALSE)
                        ->range(0, 1)
                        ->execute();
                    if (!empty($entity_ids)) {
                        $entity = $this->entityTypeManager
                            ->getStorage($entity_type_id)
                            ->load($bundle_id);
                        $event->getConfigImporter()
                            ->logError($this->t('Entities exist of type %entity_type and %bundle_label %bundle. These entities need to be deleted before importing.', [
                            '%entity_type' => $bundle_of_entity_type->getLabel(),
                            '%bundle_label' => $bundle_of_entity_type->getBundleLabel(),
                            '%bundle' => $entity->label(),
                        ]));
                    }
                }
            }
        }
    }

}

Classes

Title Deprecated Summary
BundleConfigImportValidate Entity config importer validation event subscriber.

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