class UserRole in RNG - Events and Registrations 8.2
Same name and namespace in other branches
- 8 src/Plugin/Condition/UserRole.php \Drupal\rng\Plugin\Condition\UserRole
- 3.x src/Plugin/Condition/UserRole.php \Drupal\rng\Plugin\Condition\UserRole
Provides a user role condition where all roles are matched.
Plugin annotation
@Condition(
id = "rng_user_role",
label = @Translation("User Role"),
context = {
"user" = @ContextDefinition("entity:user",
label = @Translation("User"),
required = TRUE
)
}
)
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\user\Plugin\Condition\UserRole
- class \Drupal\rng\Plugin\Condition\UserRole implements RNGConditionInterface
- class \Drupal\user\Plugin\Condition\UserRole
- 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 UserRole
File
- src/
Plugin/ Condition/ UserRole.php, line 25
Namespace
Drupal\rng\Plugin\ConditionView source
class UserRole extends CoreUserRole implements RNGConditionInterface {
/**
* {@inheritdoc}
*/
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
$form = parent::buildConfigurationForm($form, $form_state);
$form['roles']['#title'] = $this
->t('When the user has all of the following roles');
$form['roles']['#options'] = array_map('\\Drupal\\Component\\Utility\\SafeMarkup::checkPlain', $this
->getRoles());
$form['roles']['#description'] = $this
->t('If you select no roles, the condition will evaluate to TRUE for all logged-in users.');
$form['negate']['#access'] = FALSE;
return $form;
}
/**
* {@inheritdoc}
*/
public function summary() {
// Ensure roles in configuration are still existing or valid roles.
$roles = array_intersect_key($this
->getRoles(), $this->configuration['roles']);
if (!count($roles)) {
return $this
->t('Any registered user');
}
return $this
->t(empty($this->configuration['negate']) ? 'User is a member of @roles' : 'User is not a member of @roles', [
'@roles' => count($roles) > 1 ? implode(' and ', $roles) : reset($roles),
]);
}
/**
* {@inheritdoc}
*/
public function alterQuery(&$query) {
if ($query
->getEntityTypeId() != 'user') {
throw new \Exception('Query only operates on user entity type.');
}
// Ensure roles in configuration are still existing or valid roles.
$roles = array_intersect_key($this
->getRoles(), $this->configuration['roles']);
if (count($roles)) {
foreach (array_keys($roles) as $role) {
$group = $query
->andConditionGroup();
$group
->condition('roles', $role, '=');
$query
->condition($group);
}
}
}
/**
* Get a list of valid roles permitted by global settings.
*
* Anonymous and authenticated roles are automatically removed.
*
* @return array
* An array of role labels keyed by role ID.
*/
private function getRoles() {
$options = [];
foreach (Role::loadMultiple() as $role) {
/** @var \Drupal\user\RoleInterface $role */
if ($role
->getThirdPartySetting('rng', 'condition_rng_role', FALSE)) {
$options[$role
->id()] = $role
->label();
}
}
// If there are no roles enabled, then expose all roles.
if (!count($options)) {
$options = user_role_names(TRUE);
}
unset($options[AccountInterface::ANONYMOUS_ROLE]);
unset($options[AccountInterface::AUTHENTICATED_ROLE]);
return $options;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConditionPluginBase:: |
protected | property | The condition manager to proxy execute calls through. | |
ConditionPluginBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
|
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 validation handler. Overrides PluginFormInterface:: |
|
ConditionPluginBase:: |
public | function |
Overrides \Drupal\Component\Plugin\PluginBase::__construct(). Overrides ContextAwarePluginBase:: |
4 |
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 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 value for a defined context. 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. | |
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. | |
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. | |
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 |
UserRole:: |
public | function |
Modify a query with condition configuration. Overrides RNGConditionInterface:: |
|
UserRole:: |
public | function |
Form constructor. Overrides UserRole:: |
|
UserRole:: |
public | function |
Gets default configuration for this plugin. Overrides ConditionPluginBase:: |
|
UserRole:: |
public | function |
Evaluates the condition and returns TRUE or FALSE accordingly. Overrides ConditionInterface:: |
|
UserRole:: |
public | function |
The cache contexts associated with this object. Overrides ContextAwarePluginBase:: |
|
UserRole:: |
private | function | Get a list of valid roles permitted by global settings. | |
UserRole:: |
public | function |
Form submission handler. Overrides ConditionPluginBase:: |
|
UserRole:: |
public | function |
Provides a human readable summary of the condition's configuration. Overrides UserRole:: |