public function EntityPathAliasCreateDeriver::getDerivativeDefinitions in Rules 8.3
Gets the definition of all derivatives of a base plugin.
Parameters
array $base_plugin_definition: The definition array of the base plugin.
Return value
array An array of full derivative definitions keyed on derivative id.
Overrides DeriverBase::getDerivativeDefinitions
See also
getDerivativeDefinition()
File
- src/
Plugin/ RulesAction/ EntityPathAliasCreateDeriver.php, line 52
Class
- EntityPathAliasCreateDeriver
- Derives entity create plugin definitions based on content entity types.
Namespace
Drupal\rules\Plugin\RulesActionCode
public function getDerivativeDefinitions($base_plugin_definition) {
foreach ($this->entityTypeManager
->getDefinitions() as $entity_type_id => $entity_type) {
// Only allow content entities and ignore configuration entities.
if (!$entity_type instanceof ContentEntityTypeInterface) {
continue;
}
$this->derivatives["entity:{$entity_type_id}"] = [
'label' => $this
->t('Create a @entity_type path alias', [
'@entity_type' => $entity_type
->getSingularLabel(),
]),
'category' => $this
->t('Path'),
'provider' => 'path_alias',
'entity_type_id' => $entity_type_id,
'context_definitions' => [
'entity' => ContextDefinition::create("entity:{$entity_type_id}")
->setLabel($entity_type
->getLabel())
->setRequired(TRUE)
->setDescription($this
->t('The @entity_type for which to create a path alias.', [
'@entity_type' => $entity_type
->getSingularLabel(),
])),
'alias' => ContextDefinition::create('string')
->setLabel($this
->t('Path alias'))
->setRequired(TRUE)
->setDescription($this
->t("Specify an alternative path by which the content can be accessed. For example, '/about' for an about page. Use an absolute path and do not add a trailing slash.")),
],
'provides' => [],
] + $base_plugin_definition;
}
return $this->derivatives;
}