public function MenuLinkManager::getDefinitions in Drupal 10
Same name and namespace in other branches
- 8 core/lib/Drupal/Core/Menu/MenuLinkManager.php \Drupal\Core\Menu\MenuLinkManager::getDefinitions()
- 9 core/lib/Drupal/Core/Menu/MenuLinkManager.php \Drupal\Core\Menu\MenuLinkManager::getDefinitions()
Gets the definition of all plugins for this type.
Return value
mixed[] An array of plugin definitions (empty array if no definitions were found). Keys are plugin IDs.
Overrides DiscoveryInterface::getDefinitions
See also
\Drupal\Core\Plugin\FilteredPluginManagerInterface::getFilteredDefinitions()
2 calls to MenuLinkManager::getDefinitions()
- MenuLinkManager::rebuild in core/
lib/ Drupal/ Core/ Menu/ MenuLinkManager.php - Triggers discovery, save, and cleanup of discovered links.
- MenuLinkManager::resetInstance in core/
lib/ Drupal/ Core/ Menu/ MenuLinkManager.php - Resets the menu link to its default settings.
File
- core/
lib/ Drupal/ Core/ Menu/ MenuLinkManager.php, line 162
Class
- MenuLinkManager
- Manages discovery, instantiation, and tree building of menu link plugins.
Namespace
Drupal\Core\MenuCode
public function getDefinitions() {
// Since this function is called rarely, instantiate the discovery here.
$definitions = $this
->getDiscovery()
->getDefinitions();
$this->moduleHandler
->alter('menu_links_discovered', $definitions);
foreach ($definitions as $plugin_id => &$definition) {
$definition['id'] = $plugin_id;
$this
->processDefinition($definition, $plugin_id);
}
// If this plugin was provided by a module that does not exist, remove the
// plugin definition.
// @todo Address what to do with an invalid plugin.
// https://www.drupal.org/node/2302623
foreach ($definitions as $plugin_id => $plugin_definition) {
if (!empty($plugin_definition['provider']) && !$this->moduleHandler
->moduleExists($plugin_definition['provider'])) {
unset($definitions[$plugin_id]);
}
}
return $definitions;
}