You are here

public function EntityFieldStorageConfig::calculateDependencies in Drupal 8

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 Entity::calculateDependencies

See also

\Drupal\Core\Config\Entity\ConfigDependencyManager

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

File

core/modules/migrate_drupal/src/Plugin/migrate/destination/EntityFieldStorageConfig.php, line 85

Class

EntityFieldStorageConfig
Deprecated. Destination with Drupal specific config dependencies.

Namespace

Drupal\migrate_drupal\Plugin\migrate\destination

Code

public function calculateDependencies() {
  $this->dependencies = parent::calculateDependencies();

  // Add a dependency on the module that provides the field type using the
  // source plugin configuration.
  $source_configuration = $this->migration
    ->getSourceConfiguration();
  if (isset($source_configuration['constants']['type'])) {
    $field_type = $this->fieldTypePluginManager
      ->getDefinition($source_configuration['constants']['type']);
    $this
      ->addDependency('module', $field_type['provider']);
  }
  return $this->dependencies;
}