public function LogintobogganRegister::save in LoginToboggan 8
Form submission handler for the 'save' action.
Normally this method should be overridden to provide specific messages to the user and redirect the form after the entity has been saved.
Parameters
array $form: An associative array containing the structure of the form.
\Drupal\Core\Form\FormStateInterface $form_state: The current state of the form.
Return value
int Either SAVED_NEW or SAVED_UPDATED, depending on the operation performed.
Overrides RegisterForm::save
File
- src/
Form/ LogintobogganRegister.php, line 132
Class
- LogintobogganRegister
- Provide alternative registration form to include LT components and submit.
Namespace
Drupal\logintoboggan\FormCode
public function save(array $form, FormStateInterface $form_state) {
$account = $this->entity;
$admin = $form_state
->getValue('administer_users');
$notify = !$form_state
->isValueEmpty('notify');
// Save has no return value so this cannot be tested.
// Assume save has gone through correctly.
$account
->save();
$form_state
->set('user', $account);
$form_state
->setValue('uid', $account
->id());
$this
->logger('user')
->notice('New user: %name %email.', [
'%name' => $form_state
->getValue('name'),
'%email' => '<' . $form_state
->getValue('mail') . '>',
'type' => $account
->link($this
->t('Edit'), 'edit-form'),
]);
$immediate = \Drupal::config('logintoboggan.settings')
->get('immediate_login_on_register');
// New administrative account without notification.
if ($admin && !$notify) {
$this
->messenger()
->addStatus($this
->t('Created a new user account for <a href=":url">%name</a>.
No email has been sent.', [
':url' => $account
->toUrl()
->toString(),
'%name' => $account
->getAccountName(),
]));
}
elseif (!$admin && !\Drupal::config('user.settings')
->get('verify_mail') && $account
->isActive() && $immediate == '1') {
user_login_finalize($account);
// Notify after login so that we get hash based on last login.
_user_mail_notify('register_no_approval_required', $account);
$this
->messenger()
->addStatus($this
->t('Registration successful.'));
$redirect_setting = \Drupal::config('logintoboggan.settings')
->get('redirect_on_register');
$redirect_on_register = !empty($redirect_setting) ? $redirect_setting : '/';
$redirect = LogintobogganUtility::processRedirect($redirect_on_register, $account);
$form_state
->setRedirectUrl($redirect);
}
elseif ($account
->isActive() || $notify) {
if (!$account
->getEmail() && $notify) {
$this
->messenger()
->addMessage($this
->t('The new user <a href=":url">%name</a> was created
without an email address so no welcome message was sent', [
':url' => Url::fromRoute('entity.user.edit_form', [
'user' => $account
->id(),
])
->toString(),
'%name' => $account
->get('name')->value,
]));
}
else {
$op = $notify ? 'register_admin_created' : 'register_no_approval_required';
if (_user_mail_notify($op, $account)) {
if ($notify) {
$this
->messenger()
->addMessage($this
->t('A welcome message with further instructions
has been emailed to the new user <a href=":url">%name</a>.', [
':url' => Url::fromRoute('entity.user.edit_form', [
'user' => $account
->id(),
])
->toString(),
'%name' => $account
->get('name')->value,
]));
}
else {
$this
->messenger()
->addMessage($this
->t('A welcome message with further
instructions has been sent to your email address.'));
$form_state
->setRedirect('<front>');
}
}
}
}
else {
_user_mail_notify('register_pending_approval', $account);
$this
->messenger()
->addMessage($this
->t('Thank you for applying for an account. Your account
is currently pending approval by the site administrator..<br />In the meantime,
a welcome message with further instructions has been sent to your email address.'));
$form_state
->setRedirect('<front>');
}
}