rules-8.x-3.x-dev/src/Plugin/RulesAction/UserRoleRemove.php
src/Plugin/RulesAction/UserRoleRemove.php
<?php
namespace Drupal\rules\Plugin\RulesAction;
use Drupal\Core\StringTranslation\TranslatableMarkup;
use Drupal\rules\Context\ContextDefinition;
use Drupal\rules\Core\Attribute\RulesAction;
use Drupal\rules\Core\RulesActionBase;
use Drupal\rules\Exception\InvalidArgumentException;
use Drupal\rules\TypedData\Options\RolesOptions;
use Drupal\user\UserInterface;
/**
* Provides a 'Remove user role' action.
*
* @RulesAction(
* id = "rules_user_role_remove",
* label = @Translation("Remove user role"),
* category = @Translation("User"),
* context_definitions = {
* "user" = @ContextDefinition("entity:user",
* label = @Translation("User"),
* description = @Translation("The user whose roles should be changed."),
* assignment_restriction = "selector"
* ),
* "roles" = @ContextDefinition("entity:user_role",
* label = @Translation("Roles"),
* description = @Translation("The user role(s) to remove."),
* options_provider = "\Drupal\rules\TypedData\Options\RolesOptions",
* multiple = TRUE
* ),
* }
* )
*/
#[RulesAction(
id: "rules_user_role_remove",
label: new TranslatableMarkup("Remove user role"),
category: new TranslatableMarkup("User"),
context_definitions: [
"user" => new ContextDefinition(
data_type: "entity:user",
label: new TranslatableMarkup("User"),
description: new TranslatableMarkup("The user whose roles should be changed."),
assignment_restriction: "selector"
),
"roles" => new ContextDefinition(
data_type: "entity:user_role",
label: new TranslatableMarkup("Roles"),
description: new TranslatableMarkup("The user role(s) to remove."),
options_provider: RolesOptions::class,
multiple: TRUE
),
]
)]
class UserRoleRemove extends RulesActionBase {
/**
* Flag that indicates if the entity should be auto-saved later.
*
* @var bool
*/
protected $saveLater = FALSE;
/**
* Remove role from a user.
*
* @param \Drupal\user\UserInterface $user
* User object the roles should be removed from.
* @param \Drupal\user\RoleInterface[] $roles
* Array of user roles.
*
* @throws \Drupal\rules\Exception\InvalidArgumentException
*/
protected function doExecute(UserInterface $user, array $roles) {
foreach ($roles as $role) {
// Check if user has role.
if ($user->hasRole($role->id())) {
// If you try to add anonymous or authenticated role to user, Drupal
// will throw an \InvalidArgumentException. Anonymous or authenticated
// role ID must not be assigned manually.
try {
$user->removeRole($role->id());
}
catch (\InvalidArgumentException $e) {
throw new InvalidArgumentException($e->getMessage());
}
// Set flag that indicates if the entity should be auto-saved later.
$this->saveLater = TRUE;
}
}
}
/**
* {@inheritdoc}
*/
public function autoSaveContext(): array {
if ($this->saveLater) {
return ['user'];
}
return [];
}
}
