PasswordReset.php in Password Policy 8.3
File
src/Form/PasswordReset.php
View source
<?php
namespace Drupal\password_policy\Form;
use Drupal\Core\Form\FormBase;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Session\AccountInterface;
use Drupal\Core\Url;
use Drupal\user\RoleStorageInterface;
use Drupal\user\UserStorageInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
class PasswordReset extends FormBase {
protected $roleStorage;
protected $userStorage;
public static function create(ContainerInterface $container) {
$entity_type_manager = $container
->get('entity_type.manager');
return new static($entity_type_manager
->getStorage('user_role'), $entity_type_manager
->getStorage('user'));
}
public function __construct(RoleStorageInterface $role_storage, UserStorageInterface $user_storage) {
$this->roleStorage = $role_storage;
$this->userStorage = $user_storage;
}
public function getFormId() {
return 'password_policy_reset_form';
}
public function buildForm(array $form, FormStateInterface $form_state) {
$options = [];
foreach ($this->roleStorage
->loadMultiple() as $role) {
$options[$role
->id()] = $role
->label();
}
unset($options[AccountInterface::ANONYMOUS_ROLE]);
$form['roles'] = [
'#type' => 'checkboxes',
'#title' => $this
->t('Roles'),
'#description' => $this
->t('Force password reset of selected roles.'),
'#options' => $options,
];
$form['exclude_myself'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Exclude Myself'),
'#description' => $this
->t('Exclude your account if you are included in the roles.'),
'#default_value' => '1',
];
$form['save'] = [
'#type' => 'submit',
'#value' => $this
->t('Save'),
];
return $form;
}
public function submitForm(array &$form, FormStateInterface $form_state) {
if ($roles = array_filter($form_state
->getValue('roles'))) {
foreach ($roles as $key => $role) {
$roles[$key] = $this->roleStorage
->load($role)
->label();
}
$properties = [];
if (!array_key_exists(AccountInterface::AUTHENTICATED_ROLE, $roles)) {
$properties['roles'] = array_keys($roles);
}
$users = $this->userStorage
->loadByProperties($properties);
$exclude_myself = $form_state
->getValue('exclude_myself') == '1';
foreach ($users as $user) {
if ($exclude_myself && $user
->id() === $this
->currentUser()
->id()) {
continue;
}
if ($user
->hasRole(AccountInterface::ANONYMOUS_ROLE)) {
continue;
}
$user
->set('field_password_expiration', '1');
$user
->save();
}
$this
->messenger()
->addMessage($this
->formatPlural(count($roles), 'Reset the %roles role.', 'Reset the %roles roles.', [
'%roles' => implode(', ', array_values($roles)),
]));
}
else {
$this
->messenger()
->addWarning($this
->t('No roles selected.'));
}
$form_state
->setRedirectUrl(new Url('entity.password_policy.collection'));
}
}