3 namespace Drupal\user\Plugin\Action;
5 use Drupal\Core\Action\ConfigurableActionBase;
6 use Drupal\Core\Entity\DependencyTrait;
7 use Drupal\Core\Entity\EntityTypeInterface;
8 use Drupal\Core\Form\FormStateInterface;
9 use Drupal\Core\Plugin\ContainerFactoryPluginInterface;
10 use Drupal\Core\Session\AccountInterface;
11 use Drupal\user\RoleInterface;
12 use Symfony\Component\DependencyInjection\ContainerInterface;
15 * Provides a base class for operations to change a user's role.
17 abstract class ChangeUserRoleBase extends ConfigurableActionBase implements ContainerFactoryPluginInterface {
22 * The user role entity type.
24 * @var \Drupal\Core\Entity\EntityTypeInterface
26 protected $entityType;
31 public function __construct(array $configuration, $plugin_id, $plugin_definition, EntityTypeInterface $entity_type) {
32 parent::__construct($configuration, $plugin_id, $plugin_definition);
33 $this->entityType = $entity_type;
39 public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
44 $container->get('entity.manager')->getDefinition('user_role')
51 public function defaultConfiguration() {
60 public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
61 $roles = user_role_names(TRUE);
62 unset($roles[RoleInterface::AUTHENTICATED_ID]);
65 '#title' => t('Role'),
67 '#default_value' => $this->configuration['rid'],
76 public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
77 $this->configuration['rid'] = $form_state->getValue('rid');
83 public function calculateDependencies() {
84 if (!empty($this->configuration['rid'])) {
85 $prefix = $this->entityType->getConfigPrefix() . '.';
86 $this->addDependency('config', $prefix . $this->configuration['rid']);
88 return $this->dependencies;
94 public function access($object, AccountInterface $account = NULL, $return_as_object = FALSE) {
95 /** @var \Drupal\user\UserInterface $object */
96 $access = $object->access('update', $account, TRUE)
97 ->andIf($object->roles->access('edit', $account, TRUE));
99 return $return_as_object ? $access : $access->isAllowed();