public function Menu::calculateDependencies in Workbench Access 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 AccessControlHierarchyBase::calculateDependencies
See also
\Drupal\Core\Config\Entity\ConfigDependencyManager
\Drupal\Core\Entity\EntityInterface::getConfigDependencyName()
File
- src/
Plugin/ AccessControlHierarchy/ Menu.php, line 311
Class
- Menu
- Defines a hierarchy based on a Menu.
Namespace
Drupal\workbench_access\Plugin\AccessControlHierarchyCode
public function calculateDependencies() {
$entity_type_map = [
'menu' => 'menus',
'node_type' => 'bundles',
];
$dependencies = [];
foreach ($entity_type_map as $entity_type => $configuration_key) {
$dependencies = array_merge($dependencies, $this->entityTypeManager
->getStorage($entity_type)
->loadMultiple($this->configuration[$configuration_key]));
}
return array_reduce($dependencies, function (array $carry, ConfigEntityInterface $entity) {
$carry[$entity
->getConfigDependencyKey()][] = $entity
->getConfigDependencyName();
return $carry;
}, []);
}