class ActionManager

Same name and namespace in other branches
  1. 11.x core/lib/Drupal/Core/Action/ActionManager.php \Drupal\Core\Action\ActionManager
  2. 10 core/lib/Drupal/Core/Action/ActionManager.php \Drupal\Core\Action\ActionManager
  3. 9 core/lib/Drupal/Core/Action/ActionManager.php \Drupal\Core\Action\ActionManager
  4. 8.9.x core/lib/Drupal/Core/Action/ActionManager.php \Drupal\Core\Action\ActionManager

Provides an Action plugin manager.

Hierarchy

Expanded class hierarchy of ActionManager

See also

\Drupal\Core\Annotation\Action

\Drupal\Core\Action\ActionInterface

\Drupal\Core\Action\ActionBase

Plugin API

1 string reference to 'ActionManager'
core.services.yml in core/core.services.yml
core/core.services.yml
1 service uses ActionManager
plugin.manager.action in core/core.services.yml
Drupal\Core\Action\ActionManager

File

core/lib/Drupal/Core/Action/ActionManager.php, line 20

Namespace

Drupal\Core\Action
View source
class ActionManager extends DefaultPluginManager implements CategorizingPluginManagerInterface {
  use CategorizingPluginManagerTrait;
  
  /**
   * Constructs a new class instance.
   *
   * @param \Traversable $namespaces
   *   An object that implements \Traversable which contains the root paths
   *   keyed by the corresponding namespace to look for plugin implementations.
   * @param \Drupal\Core\Cache\CacheBackendInterface $cache_backend
   *   Cache backend instance to use.
   * @param \Drupal\Core\Extension\ModuleHandlerInterface $module_handler
   *   The module handler to invoke the alter hook with.
   */
  public function __construct(\Traversable $namespaces, CacheBackendInterface $cache_backend, ModuleHandlerInterface $module_handler) {
    parent::__construct('Plugin/Action', $namespaces, $module_handler, ActionInterface::class, Action::class, 'Drupal\\Core\\Annotation\\Action');
    $this->alterInfo('action_info');
    $this->setCacheBackend($cache_backend, 'action_info');
  }
  
  /**
   * Gets the plugin definitions for this entity type.
   *
   * @param string $type
   *   The entity type name.
   *
   * @return array
   *   An array of plugin definitions for this entity type.
   */
  public function getDefinitionsByType($type) {
    return array_filter($this->getDefinitions(), function ($definition) use ($type) {
      return $definition['type'] === $type;
    });
  }

}

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