You are here

public function Entity::calculateDependencies in Drupal 8

Same name in this branch
  1. 8 core/modules/views/src/Plugin/views/area/Entity.php \Drupal\views\Plugin\views\area\Entity::calculateDependencies()
  2. 8 core/modules/views/src/Plugin/views/argument_validator/Entity.php \Drupal\views\Plugin\views\argument_validator\Entity::calculateDependencies()
  3. 8 core/modules/migrate/src/Plugin/migrate/destination/Entity.php \Drupal\migrate\Plugin\migrate\destination\Entity::calculateDependencies()
Same name and namespace in other branches
  1. 9 core/modules/views/src/Plugin/views/argument_validator/Entity.php \Drupal\views\Plugin\views\argument_validator\Entity::calculateDependencies()
  2. 10 core/modules/views/src/Plugin/views/argument_validator/Entity.php \Drupal\views\Plugin\views\argument_validator\Entity::calculateDependencies()

Calculates dependencies for the configured plugin.

Dependencies are saved in the plugin's configuration entity and are used to determine configuration synchronization order. For example, if the plugin integrates with specific user roles, this method should return an array of dependencies listing the specified roles.

Return value

array An array of dependencies grouped by type (config, content, module, theme). For example:

array(
  'config' => array(
    'user.role.anonymous',
    'user.role.authenticated',
  ),
  'content' => array(
    'node:article:f0a189e6-55fb-47fb-8005-5bef81c44d6d',
  ),
  'module' => array(
    'node',
    'user',
  ),
  'theme' => array(
    'seven',
  ),
);

Overrides PluginBase::calculateDependencies

See also

\Drupal\Core\Config\Entity\ConfigDependencyManager

\Drupal\Core\Entity\EntityInterface::getConfigDependencyName()

1 call to Entity::calculateDependencies()
User::calculateDependencies in core/modules/user/src/Plugin/views/argument_validator/User.php
Calculates dependencies for the configured plugin.
1 method overrides Entity::calculateDependencies()
User::calculateDependencies in core/modules/user/src/Plugin/views/argument_validator/User.php
Calculates dependencies for the configured plugin.

File

core/modules/views/src/Plugin/views/argument_validator/Entity.php, line 244

Class

Entity
Defines a argument validator plugin for each entity type.

Namespace

Drupal\views\Plugin\views\argument_validator

Code

public function calculateDependencies() {
  $dependencies = parent::calculateDependencies();
  $entity_type_id = $this->definition['entity_type'];
  $bundle_entity_type = $this->entityTypeManager
    ->getDefinition($entity_type_id)
    ->getBundleEntityType();

  // The bundle entity type might not exist. For example, users do not have
  // bundles.
  if ($this->entityTypeManager
    ->hasHandler($bundle_entity_type, 'storage')) {
    $bundle_entity_storage = $this->entityTypeManager
      ->getStorage($bundle_entity_type);
    foreach ($bundle_entity_storage
      ->loadMultiple(array_keys($this->options['bundles'])) as $bundle_entity) {
      $dependencies[$bundle_entity
        ->getConfigDependencyKey()][] = $bundle_entity
        ->getConfigDependencyName();
    }
  }
  return $dependencies;
}