View source
<?php
namespace Drupal\change_pwd_page\Form;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Session\AccountInterface;
use Drupal\Component\Utility\Crypt;
use Drupal\Core\Form\FormBase;
use Psr\Log\LoggerInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;
class ChangePasswordResetForm extends FormBase {
protected $logger;
public function __construct(LoggerInterface $logger) {
$this->logger = $logger;
}
public static function create(ContainerInterface $container) {
return new static($container
->get('logger.factory')
->get('user'));
}
public function getFormId() {
return 'user_pass_reset';
}
public function buildForm(array $form, FormStateInterface $form_state, AccountInterface $user = NULL, $expiration_date = NULL, $timestamp = NULL, $hash = NULL) {
if ($expiration_date) {
$form['message'] = [
'#markup' => $this
->t('<p>This is a one-time login for %user_name and will expire on
%expiration_date.</p><p>Click on this button to log in to the site and change your password.</p>', [
'%user_name' => $user
->getDisplayName(),
'%expiration_date' => $expiration_date,
]),
];
$form['#title'] = $this
->t('Reset password');
}
else {
$form['message'] = [
'#markup' => $this
->t('<p>This is a one-time login for %user_name.</p><p>Click on this button to log in to the site and change your password.</p>', [
'%user_name' => $user
->getDisplayName(),
]),
];
$form['#title'] = $this
->t('Set password');
}
$form['user'] = [
'#type' => 'value',
'#value' => $user,
];
$form['timestamp'] = [
'#type' => 'value',
'#value' => $timestamp,
];
$form['help'] = [
'#markup' => '<p>' . $this
->t('This login can be used only once.') . '</p>',
];
$form['actions'] = [
'#type' => 'actions',
];
$form['actions']['submit'] = [
'#type' => 'submit',
'#value' => $this
->t('Log in'),
];
return $form;
}
public function submitForm(array &$form, FormStateInterface $form_state) {
$user = $form_state
->getValue('user');
user_login_finalize($user);
$this->logger
->notice('User %name used one-time login link at time %timestamp.', [
'%name' => $user
->getDisplayName(),
'%timestamp' => $form_state
->getValue('timestamp'),
]);
$this
->messenger()
->addStatus($this
->t('You have just used your one-time login link. It is no longer necessary to use this link to log in. Please change your password.'));
$token = Crypt::randomBytesBase64(55);
$_SESSION['pass_reset_' . $user
->id()] = $token;
$form_state
->setRedirect('change_pwd_page.change_password_form', [
'user' => $user
->id(),
], [
'query' => [
'pass-reset-token' => $token,
],
'absolute' => TRUE,
]);
}
}