class RemoveRoleUser

Same name and namespace in other branches
  1. 11.x core/modules/user/src/Plugin/Action/RemoveRoleUser.php \Drupal\user\Plugin\Action\RemoveRoleUser

Removes a role from a user.

Plugin annotation


@Action(
  id = "user_remove_role_action",
  label = @Translation("Remove a role from the selected users"),
  type = "user"
)

Hierarchy

Expanded class hierarchy of RemoveRoleUser

1 file declares its use of RemoveRoleUser
RemoveRoleUserTest.php in core/modules/user/tests/src/Unit/Plugin/Action/RemoveRoleUserTest.php

File

core/modules/user/src/Plugin/Action/RemoveRoleUser.php, line 14

Namespace

Drupal\user\Plugin\Action
View source
class RemoveRoleUser extends ChangeUserRoleBase {
  
  /**
   * {@inheritdoc}
   */
  public function execute($account = NULL) {
    $rid = $this->configuration['rid'];
    // Skip removing the role from the user if they already don't have it.
    if ($account !== FALSE && $account->hasRole($rid)) {
      // For efficiency manually save the original account before applying
      // any changes.
      $account->original = clone $account;
      $account->removeRole($rid);
      $account->save();
    }
  }

}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.