class RulesActionBase
Base class for rules actions.
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements \Drupal\Component\Plugin\PluginInspectionInterface, \Drupal\Component\Plugin\DerivativeInspectionInterface
- class \Drupal\Core\Plugin\PluginBase extends \Drupal\Component\Plugin\PluginBase uses \Drupal\Core\StringTranslation\StringTranslationTrait, \Drupal\Core\DependencyInjection\DependencySerializationTrait, \Drupal\Core\Messenger\MessengerTrait
- class \Drupal\rules\Core\RulesActionBase extends \Drupal\Core\Plugin\PluginBase implements \Drupal\rules\Core\RulesActionInterface uses \Drupal\Core\Plugin\ContextAwarePluginTrait, \Drupal\rules\Context\ContextProviderTrait, \Drupal\rules\Core\ExecutablePluginTrait, \Drupal\rules\Core\ConfigurationAccessControlTrait
- class \Drupal\Core\Plugin\PluginBase extends \Drupal\Component\Plugin\PluginBase uses \Drupal\Core\StringTranslation\StringTranslationTrait, \Drupal\Core\DependencyInjection\DependencySerializationTrait, \Drupal\Core\Messenger\MessengerTrait
Expanded class hierarchy of RulesActionBase
37 files declare their use of RulesActionBase
- DataCalculateValue.php in src/
Plugin/ RulesAction/ DataCalculateValue.php - DataConvert.php in src/
Plugin/ RulesAction/ DataConvert.php - DataListItemAdd.php in src/
Plugin/ RulesAction/ DataListItemAdd.php - DataListItemRemove.php in src/
Plugin/ RulesAction/ DataListItemRemove.php - DataSet.php in src/
Plugin/ RulesAction/ DataSet.php
File
-
src/
Core/ RulesActionBase.php, line 15
Namespace
Drupal\rules\CoreView source
abstract class RulesActionBase extends PluginBase implements RulesActionInterface {
use ContextAwarePluginTrait {
getContextValue as protected traitGetContextValue;
}
use ContextProviderTrait;
use ExecutablePluginTrait;
use ConfigurationAccessControlTrait;
/**
* The plugin configuration.
*
* @var array
*/
protected $configuration;
/**
* {@inheritdoc}
*/
public function getContextValue($name) {
try {
return $this->traitGetContextValue($name);
} catch (ContextException $e) {
// Catch the undocumented exception thrown when no context value is set
// for a required context.
// @todo Remove once https://www.drupal.org/node/2677162 is fixed.
if (strpos($e->getMessage(), 'context is required') === FALSE) {
throw $e;
}
}
}
/**
* {@inheritdoc}
*/
public function refineContextDefinitions(array $selected_data) {
// Do not refine anything by default.
}
/**
* {@inheritdoc}
*/
public function assertMetadata(array $selected_data) {
// Nothing to assert by default.
return [];
}
/**
* {@inheritdoc}
*
* @todo this documentation is not actually inherited from any interface.
*/
public function getConfiguration() {
return [
'id' => $this->getPluginId(),
] + $this->configuration;
}
/**
* {@inheritdoc}
*
* @todo this documentation is not actually inherited from any interface.
*/
public function setConfiguration(array $configuration) {
$this->configuration = $configuration + $this->defaultConfiguration();
return $this;
}
/**
* {@inheritdoc}
*
* @todo this documentation is not actually inherited from any interface.
* Do we need this empty implementation?
*/
public function defaultConfiguration() {
return [];
}
/**
* {@inheritdoc}
*
* @todo this documentation is not actually inherited from any interface.
* Do we need this empty implementation?
*/
public function calculateDependencies() {
return [];
}
/**
* {@inheritdoc}
*
* @todo this documentation is not actually inherited from any interface.
* Do we need this empty implementation?
*/
public function executeMultiple(array $objects) {
// @todo Remove this once it is removed from the interface.
}
/**
* {@inheritdoc}
*/
public function autoSaveContext() {
// Per default no context parameters will be auto saved.
return [];
}
/**
* {@inheritdoc}
*/
public function access($object, AccountInterface $account = NULL, $return_as_object = FALSE) {
// Just deny access per default for now.
if ($return_as_object) {
return AccessResult::forbidden();
}
return FALSE;
}
/**
* {@inheritdoc}
*/
public function execute() {
// Provide a reasonable default implementation that calls doExecute() while
// passing the defined context as arguments.
$args = [];
foreach ($this->getContextDefinitions() as $name => $definition) {
$value = $this->getContextValue($name);
$type = $definition->toArray()['type'];
if (substr($type, 0, 6) == 'entity') {
if (is_array($value) && is_string($value[0])) {
$value = array_map([
$this,
'upcastEntityId',
], $value, array_fill(0, count($value), $type));
}
elseif (is_string($value)) {
$value = $this->upcastEntityId($value, $type);
}
}
$args[$name] = $value;
}
call_user_func_array([
$this,
'doExecute',
], $args);
}
}
Members
Title Sort descending | Modifiers | Object type | Summary | Member alias | Overriden Title | Overrides |
---|---|---|---|---|---|---|
ConfigurationAccessControlTrait::checkConfigurationAccess | public | function | Checks configuration permission. | |||
ContextAwarePluginTrait::$context | protected | property | The data objects representing the context of this plugin. | |||
ContextAwarePluginTrait::$initializedContextConfig | protected | property | Tracks whether the context has been initialized from configuration. | |||
ContextAwarePluginTrait::getCacheContexts | public | function | 9 | |||
ContextAwarePluginTrait::getCacheMaxAge | public | function | 7 | |||
ContextAwarePluginTrait::getCacheTags | public | function | 4 | |||
ContextAwarePluginTrait::getContext | public | function | ||||
ContextAwarePluginTrait::getContextDefinition | public | function | ||||
ContextAwarePluginTrait::getContextDefinitions | public | function | ||||
ContextAwarePluginTrait::getContextMapping | public | function | ||||
ContextAwarePluginTrait::getContexts | public | function | ||||
ContextAwarePluginTrait::getContextValue | public | function | Aliased as: traitGetContextValue | |||
ContextAwarePluginTrait::getContextValues | public | function | ||||
ContextAwarePluginTrait::getPluginDefinition | abstract public | function | 1 | |||
ContextAwarePluginTrait::setContext | public | function | 1 | |||
ContextAwarePluginTrait::setContextMapping | public | function | ||||
ContextAwarePluginTrait::setContextValue | public | function | ||||
ContextAwarePluginTrait::validateContexts | public | function | ||||
ContextProviderTrait::$providedContext | protected | property | The data objects that are provided by this plugin. | |||
ContextProviderTrait::getProvidedContext | public | function | ||||
ContextProviderTrait::getProvidedContextDefinition | public | function | ||||
ContextProviderTrait::getProvidedContextDefinitions | public | function | ||||
ContextProviderTrait::setProvidedValue | public | function | ||||
ContextProviderTrait::upcastEntityId | public | function | Upcasts an entity id to a full entity object. | |||
ExecutablePluginTrait::getLabelValue | protected | function | Get the translated label from the plugin definition. | |||
ExecutablePluginTrait::summary | public | function | Get the translated summary from the label annotation. | 4 | ||
PluginInspectionInterface::getPluginId | public | function | Gets the plugin_id of the plugin instance. | 2 | ||
RulesActionBase::$configuration | protected | property | The plugin configuration. | |||
RulesActionBase::access | public | function | Checks object access. | Overrides RulesActionInterface::access | ||
RulesActionBase::assertMetadata | public | function | Asserts additional metadata for the selected data. | Overrides ContextAwarePluginInterface::assertMetadata | ||
RulesActionBase::autoSaveContext | public | function | Returns a list of context names that should be auto-saved after execution. | Overrides RulesActionInterface::autoSaveContext | 14 | |
RulesActionBase::calculateDependencies | public | function | @todo this documentation is not actually inherited from any interface. Do we need this empty implementation? |
|||
RulesActionBase::defaultConfiguration | public | function | @todo this documentation is not actually inherited from any interface. Do we need this empty implementation? |
|||
RulesActionBase::execute | public | function | Executes the plugin. | Overrides ExecutableInterface::execute | 2 | |
RulesActionBase::executeMultiple | public | function | @todo this documentation is not actually inherited from any interface. Do we need this empty implementation? |
|||
RulesActionBase::getConfiguration | public | function | @todo this documentation is not actually inherited from any interface. | |||
RulesActionBase::getContextValue | public | function | Gets the value for a defined context. | Overrides ContextAwarePluginInterface::getContextValue | ||
RulesActionBase::refineContextDefinitions | public | function | Refines used and provided context definitions based upon context values. | Overrides ContextAwarePluginInterface::refineContextDefinitions | 5 | |
RulesActionBase::setConfiguration | public | function | @todo this documentation is not actually inherited from any interface. |