class CompareTokenWithToken in Rules Token 8
Same name and namespace in other branches
- 2.x src/Plugin/Condition/CompareTokenWithToken.php \Drupal\rules_token\Plugin\Condition\CompareTokenWithToken
- 1.x src/Plugin/Condition/CompareTokenWithToken.php \Drupal\rules_token\Plugin\Condition\CompareTokenWithToken
Provides a 'Compare Token with Token' condition.
Plugin annotation
@Condition(
id = "rules_token_compare_token_with_token",
label = @Translation("Compare Token with Token"),
category = @Translation("Data"),
context = {
"token_1" = @ContextDefinition("string",
label = @Translation("Token 1"),
description = @Translation("The token 1 to be compared with the token 2."),
assignment_restriction = "input",
),
"token_entity_1" = @ContextDefinition("entity",
label = @Translation("Entity of Token 1"),
description = @Translation("Select from the selector the entity used in token 1. Or if you use global tokens like [date:short] then keep this field empty."),
required = FALSE
),
"operation" = @ContextDefinition("string",
label = @Translation("Operator"),
description = @Translation("The comparison operator. Valid values are == (default), <, >, CONTAINS (for strings or arrays) and IN (for arrays or lists)."),
default_value = "==",
),
"token_2" = @ContextDefinition("string",
label = @Translation("Token 2"),
description = @Translation("The token 2 to be compared with the token 1."),
assignment_restriction = "input",
),
"token_entity_2" = @ContextDefinition("entity",
label = @Translation("Entity of Token 2"),
description = @Translation("Select from the selector the entity used in token 2. Or if you use global tokens like [date:short] then keep this field empty."),
required = FALSE
)
}
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Component\Plugin\ContextAwarePluginBase implements ContextAwarePluginInterface
- class \Drupal\Core\Plugin\ContextAwarePluginBase implements CacheableDependencyInterface, ContextAwarePluginInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\Core\Executable\ExecutablePluginBase implements ExecutableInterface
- class \Drupal\Core\Condition\ConditionPluginBase implements ConditionInterface uses ContextAwarePluginAssignmentTrait
- class \Drupal\rules\Core\RulesConditionBase implements RulesConditionInterface uses ContextProviderTrait, ConfigurationAccessControlTrait, ExecutablePluginTrait
- class \Drupal\rules_token\Plugin\Condition\CompareTokenWithToken
- class \Drupal\rules\Core\RulesConditionBase implements RulesConditionInterface uses ContextProviderTrait, ConfigurationAccessControlTrait, ExecutablePluginTrait
- class \Drupal\Core\Condition\ConditionPluginBase implements ConditionInterface uses ContextAwarePluginAssignmentTrait
- class \Drupal\Core\Executable\ExecutablePluginBase implements ExecutableInterface
- class \Drupal\Core\Plugin\ContextAwarePluginBase implements CacheableDependencyInterface, ContextAwarePluginInterface uses DependencySerializationTrait, StringTranslationTrait, TypedDataTrait
- class \Drupal\Component\Plugin\ContextAwarePluginBase implements ContextAwarePluginInterface
Expanded class hierarchy of CompareTokenWithToken
File
- src/
Plugin/ Condition/ CompareTokenWithToken.php, line 43
Namespace
Drupal\rules_token\Plugin\ConditionView source
class CompareTokenWithToken extends RulesConditionBase {
/**
* Get values of two tokens and compare it with each other.
*
* @param string $token_1
* The token to be compared against $token_2.
* @param mixed $token_entity_1
* The entity from the context used in token 1.
* @param string $operation
* Data comparison operation. Typically one of:
* - "=="
* - "<"
* - ">"
* - "contains" (for strings or arrays)
* - "IN" (for arrays or lists).
* @param string $token_2
* The token to be compared against $token_1.
* @param mixed $token_entity_2
* The entity from the context used in token 2.
*
* @return bool
* The evaluation of the condition.
*/
protected function doEvaluate($token_1, $token_entity_1, $operation, $token_2, $token_entity_2) {
// Set flag for removing token from the final text if no replacement value
// can be generated.
// For, instance, if a node body is empty then token [node:body] will return
// '[node:body]' string. Setting 'clear' to TRUE prevents such behaviour.
$token_options = [
'clear' => TRUE,
];
// Get the value of the token 1.
if ($token_1 && $token_entity_1) {
// Extract entity name from a token, for instance if token
// is [node:created] then entity name will be 'node'.
$entity_name = mb_substr($token_1, 1, strpos($token_1, ':') - 1);
$token_data = [
$entity_name => $token_entity_1,
];
$value_1 = \Drupal::token()
->replace($token_1, $token_data, $token_options);
}
elseif ($token_1) {
$value_1 = \Drupal::token()
->replace($token_1, [], $token_options);
}
// Get the value of the token 2.
if ($token_2 && $token_entity_2) {
// Extract entity name from a token, for instance if token
// is [node:created] then entity name will be 'node'.
$entity_name = mb_substr($token_2, 1, strpos($token_2, ':') - 1);
$token_data = [
$entity_name => $token_entity_2,
];
$value_2 = \Drupal::token()
->replace($token_2, $token_data, $token_options);
}
elseif ($token_2) {
$value_2 = \Drupal::token()
->replace($token_2, [], $token_options);
}
// The following code is based on the code from the 'DataComparison'
// action of 'Rules' module.
$operation = $operation ? strtolower($operation) : '==';
switch ($operation) {
case '<':
return $value_1 < $value_2;
case '>':
return $value_1 > $value_2;
case 'contains':
return is_string($value_1) && strpos($value_1, $value_2) !== FALSE || is_array($value_1) && in_array($value_2, $value_1);
case 'in':
return is_array($value_2) && in_array($value_1, $value_2);
case '==':
default:
// In case both values evaluate to FALSE, further differentiate between
// NULL values and values evaluating to FALSE.
if (!$value_1 && !$value_2) {
return isset($value_1) && isset($value_2) || !isset($value_1) && !isset($value_2);
}
return $value_1 == $value_2;
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
CompareTokenWithToken:: |
protected | function | Get values of two tokens and compare it with each other. | |
ConditionPluginBase:: |
protected | property | The condition manager to proxy execute calls through. | |
ConditionPluginBase:: |
public | function |
Form constructor. Overrides PluginFormInterface:: |
5 |
ConditionPluginBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
|
ConditionPluginBase:: |
public | function |
Gets default configuration for this plugin. Overrides ConfigurableInterface:: |
5 |
ConditionPluginBase:: |
public | function |
Executes the plugin. Overrides ExecutableInterface:: |
|
ConditionPluginBase:: |
public | function |
Gets this plugin's configuration. Overrides ConfigurableInterface:: |
|
ConditionPluginBase:: |
public | function |
Determines whether condition result will be negated. Overrides ConditionInterface:: |
|
ConditionPluginBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurableInterface:: |
|
ConditionPluginBase:: |
public | function |
Sets the executable manager class. Overrides ConditionInterface:: |
|
ConditionPluginBase:: |
public | function |
Form submission handler. Overrides PluginFormInterface:: |
5 |
ConditionPluginBase:: |
public | function |
Form validation handler. Overrides PluginFormInterface:: |
|
ConditionPluginBase:: |
public | function |
Overrides \Drupal\Component\Plugin\PluginBase::__construct(). Overrides ContextAwarePluginBase:: |
4 |
ConfigurationAccessControlTrait:: |
public | function | Checks configuration permission. | |
ContextAwarePluginAssignmentTrait:: |
protected | function | Builds a form element for assigning a context to a given slot. | |
ContextAwarePluginAssignmentTrait:: |
protected | function | Wraps the context handler. | |
ContextAwarePluginAssignmentTrait:: |
abstract protected | function | Ensures the t() method is available. | |
ContextAwarePluginBase:: |
protected | property | The data objects representing the context of this plugin. | |
ContextAwarePluginBase:: |
private | property | Data objects representing the contexts passed in the plugin configuration. | |
ContextAwarePluginBase:: |
protected | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
The cache contexts associated with this object. Overrides CacheableDependencyInterface:: |
9 |
ContextAwarePluginBase:: |
public | function |
The maximum age for which this object may be cached. Overrides CacheableDependencyInterface:: |
7 |
ContextAwarePluginBase:: |
public | function |
The cache tags associated with this object. Overrides CacheableDependencyInterface:: |
4 |
ContextAwarePluginBase:: |
public | function |
This code is identical to the Component in order to pick up a different
Context class. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Gets a mapping of the expected assignment names to their context names. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Gets the values for all defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Set a context on this plugin. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Sets a mapping of the expected assignment names to their context names. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function |
Sets the value for a defined context. Overrides ContextAwarePluginBase:: |
|
ContextAwarePluginBase:: |
public | function |
Validates the set values for the defined contexts. Overrides ContextAwarePluginInterface:: |
|
ContextAwarePluginBase:: |
public | function | Implements magic __get() method. | |
ContextProviderTrait:: |
protected | property | The data objects that are provided by this plugin. | |
ContextProviderTrait:: |
public | function | ||
ContextProviderTrait:: |
public | function | ||
ContextProviderTrait:: |
public | function | ||
ContextProviderTrait:: |
public | function | ||
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
ExecutablePluginBase:: |
public | function | Gets all configuration values. | |
ExecutablePluginBase:: |
public | function | Gets the definition of a configuration option. | |
ExecutablePluginBase:: |
public | function | Gets an array of definitions of available configuration options. | |
ExecutablePluginBase:: |
public | function | Sets the value of a particular configuration option. | |
ExecutablePluginTrait:: |
protected | function | Get the translated label from the plugin definition. | |
ExecutablePluginTrait:: |
public | function | Get the translated summary from the label annotation. | 4 |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
RulesConditionBase:: |
public | function |
Asserts additional metadata for the selected data. Overrides ContextAwarePluginInterface:: |
1 |
RulesConditionBase:: |
public | function |
Evaluates the condition and returns TRUE or FALSE accordingly. Overrides ConditionInterface:: |
5 |
RulesConditionBase:: |
public | function |
Gets the value for a defined context. Overrides ContextAwarePluginBase:: |
|
RulesConditionBase:: |
public | function |
Negates the result after evaluating this condition. Overrides RulesConditionInterface:: |
|
RulesConditionBase:: |
public | function |
Refines used and provided context definitions based upon context values. Overrides ContextAwarePluginInterface:: |
1 |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
TypedDataTrait:: |
protected | property | The typed data manager used for creating the data types. | |
TypedDataTrait:: |
public | function | Gets the typed data manager. | 2 |
TypedDataTrait:: |
public | function | Sets the typed data manager. | 2 |