annotate core/modules/user/src/AccountSettingsForm.php @ 19:fa3358dc1485 tip

Add ndrum files
author Chris Cannam
date Wed, 28 Aug 2019 13:14:47 +0100
parents af1871eacc83
children
rev   line source
Chris@0 1 <?php
Chris@0 2
Chris@0 3 namespace Drupal\user;
Chris@0 4
Chris@0 5 use Drupal\Core\Form\ConfigFormBase;
Chris@0 6 use Drupal\Core\Config\ConfigFactoryInterface;
Chris@0 7 use Drupal\Core\Extension\ModuleHandlerInterface;
Chris@0 8 use Drupal\Core\Form\FormStateInterface;
Chris@0 9 use Drupal\Core\Render\Element;
Chris@0 10 use Symfony\Component\DependencyInjection\ContainerInterface;
Chris@0 11
Chris@0 12 /**
Chris@0 13 * Configure user settings for this site.
Chris@14 14 *
Chris@14 15 * @internal
Chris@0 16 */
Chris@0 17 class AccountSettingsForm extends ConfigFormBase {
Chris@0 18
Chris@0 19 /**
Chris@0 20 * The module handler.
Chris@0 21 *
Chris@0 22 * @var \Drupal\Core\Extension\ModuleHandlerInterface
Chris@0 23 */
Chris@0 24 protected $moduleHandler;
Chris@0 25
Chris@0 26 /**
Chris@0 27 * The role storage used when changing the admin role.
Chris@0 28 *
Chris@0 29 * @var \Drupal\user\RoleStorageInterface
Chris@0 30 */
Chris@0 31 protected $roleStorage;
Chris@0 32
Chris@0 33 /**
Chris@0 34 * Constructs a \Drupal\user\AccountSettingsForm object.
Chris@0 35 *
Chris@0 36 * @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
Chris@0 37 * The factory for configuration objects.
Chris@0 38 * @param \Drupal\Core\Extension\ModuleHandlerInterface $module_handler
Chris@0 39 * The module handler.
Chris@0 40 * @param \Drupal\user\RoleStorageInterface $role_storage
Chris@0 41 * The role storage.
Chris@0 42 */
Chris@0 43 public function __construct(ConfigFactoryInterface $config_factory, ModuleHandlerInterface $module_handler, RoleStorageInterface $role_storage) {
Chris@0 44 parent::__construct($config_factory);
Chris@0 45 $this->moduleHandler = $module_handler;
Chris@0 46 $this->roleStorage = $role_storage;
Chris@0 47 }
Chris@0 48
Chris@0 49 /**
Chris@0 50 * {@inheritdoc}
Chris@0 51 */
Chris@0 52 public static function create(ContainerInterface $container) {
Chris@0 53 return new static(
Chris@0 54 $container->get('config.factory'),
Chris@0 55 $container->get('module_handler'),
Chris@0 56 $container->get('entity.manager')->getStorage('user_role')
Chris@0 57 );
Chris@0 58 }
Chris@0 59
Chris@0 60 /**
Chris@0 61 * {@inheritdoc}
Chris@0 62 */
Chris@0 63 public function getFormId() {
Chris@0 64 return 'user_admin_settings';
Chris@0 65 }
Chris@0 66
Chris@0 67 /**
Chris@0 68 * {@inheritdoc}
Chris@0 69 */
Chris@0 70 protected function getEditableConfigNames() {
Chris@0 71 return [
Chris@0 72 'system.site',
Chris@0 73 'user.mail',
Chris@0 74 'user.settings',
Chris@0 75 ];
Chris@0 76 }
Chris@0 77
Chris@0 78 /**
Chris@0 79 * {@inheritdoc}
Chris@0 80 */
Chris@0 81 public function buildForm(array $form, FormStateInterface $form_state) {
Chris@0 82 $form = parent::buildForm($form, $form_state);
Chris@0 83 $config = $this->config('user.settings');
Chris@0 84 $mail_config = $this->config('user.mail');
Chris@0 85 $site_config = $this->config('system.site');
Chris@0 86
Chris@0 87 $form['#attached']['library'][] = 'user/drupal.user.admin';
Chris@0 88
Chris@0 89 // Settings for anonymous users.
Chris@0 90 $form['anonymous_settings'] = [
Chris@0 91 '#type' => 'details',
Chris@0 92 '#title' => $this->t('Anonymous users'),
Chris@0 93 '#open' => TRUE,
Chris@0 94 ];
Chris@0 95 $form['anonymous_settings']['anonymous'] = [
Chris@0 96 '#type' => 'textfield',
Chris@0 97 '#title' => $this->t('Name'),
Chris@0 98 '#default_value' => $config->get('anonymous'),
Chris@0 99 '#description' => $this->t('The name used to indicate anonymous users.'),
Chris@0 100 '#required' => TRUE,
Chris@0 101 ];
Chris@0 102
Chris@0 103 // Administrative role option.
Chris@0 104 $form['admin_role'] = [
Chris@0 105 '#type' => 'details',
Chris@0 106 '#title' => $this->t('Administrator role'),
Chris@0 107 '#open' => TRUE,
Chris@0 108 ];
Chris@0 109 // Do not allow users to set the anonymous or authenticated user roles as the
Chris@0 110 // administrator role.
Chris@0 111 $roles = user_role_names(TRUE);
Chris@0 112 unset($roles[RoleInterface::AUTHENTICATED_ID]);
Chris@0 113
Chris@0 114 $admin_roles = $this->roleStorage->getQuery()
Chris@0 115 ->condition('is_admin', TRUE)
Chris@0 116 ->execute();
Chris@0 117 $default_value = reset($admin_roles);
Chris@0 118
Chris@0 119 $form['admin_role']['user_admin_role'] = [
Chris@0 120 '#type' => 'select',
Chris@0 121 '#title' => $this->t('Administrator role'),
Chris@0 122 '#empty_value' => '',
Chris@0 123 '#default_value' => $default_value,
Chris@0 124 '#options' => $roles,
Chris@0 125 '#description' => $this->t('This role will be automatically assigned new permissions whenever a module is enabled. Changing this setting will not affect existing permissions.'),
Chris@0 126 // Don't allow to select a single admin role in case multiple roles got
Chris@0 127 // marked as admin role already.
Chris@0 128 '#access' => count($admin_roles) <= 1,
Chris@0 129 ];
Chris@0 130
Chris@0 131 // @todo Remove this check once language settings are generalized.
Chris@0 132 if ($this->moduleHandler->moduleExists('content_translation')) {
Chris@0 133 $form['language'] = [
Chris@0 134 '#type' => 'details',
Chris@0 135 '#title' => $this->t('Language settings'),
Chris@0 136 '#open' => TRUE,
Chris@0 137 '#tree' => TRUE,
Chris@0 138 ];
Chris@0 139 $form_state->set(['content_translation', 'key'], 'language');
Chris@0 140 $form['language'] += content_translation_enable_widget('user', 'user', $form, $form_state);
Chris@0 141 }
Chris@0 142
Chris@0 143 // User registration settings.
Chris@0 144 $form['registration_cancellation'] = [
Chris@0 145 '#type' => 'details',
Chris@0 146 '#title' => $this->t('Registration and cancellation'),
Chris@0 147 '#open' => TRUE,
Chris@0 148 ];
Chris@0 149 $form['registration_cancellation']['user_register'] = [
Chris@0 150 '#type' => 'radios',
Chris@0 151 '#title' => $this->t('Who can register accounts?'),
Chris@0 152 '#default_value' => $config->get('register'),
Chris@0 153 '#options' => [
Chris@18 154 UserInterface::REGISTER_ADMINISTRATORS_ONLY => $this->t('Administrators only'),
Chris@18 155 UserInterface::REGISTER_VISITORS => $this->t('Visitors'),
Chris@18 156 UserInterface::REGISTER_VISITORS_ADMINISTRATIVE_APPROVAL => $this->t('Visitors, but administrator approval is required'),
Chris@17 157 ],
Chris@0 158 ];
Chris@0 159 $form['registration_cancellation']['user_email_verification'] = [
Chris@0 160 '#type' => 'checkbox',
Chris@0 161 '#title' => $this->t('Require email verification when a visitor creates an account'),
Chris@0 162 '#default_value' => $config->get('verify_mail'),
Chris@17 163 '#description' => $this->t('New users will be required to validate their email address prior to logging into the site, and will be assigned a system-generated password. With this setting disabled, users will be logged in immediately upon registering, and may select their own passwords during registration.'),
Chris@0 164 ];
Chris@0 165 $form['registration_cancellation']['user_password_strength'] = [
Chris@0 166 '#type' => 'checkbox',
Chris@0 167 '#title' => $this->t('Enable password strength indicator'),
Chris@0 168 '#default_value' => $config->get('password_strength'),
Chris@0 169 ];
Chris@0 170 $form['registration_cancellation']['user_cancel_method'] = [
Chris@0 171 '#type' => 'radios',
Chris@0 172 '#title' => $this->t('When cancelling a user account'),
Chris@0 173 '#default_value' => $config->get('cancel_method'),
Chris@0 174 '#description' => $this->t('Users with the %select-cancel-method or %administer-users <a href=":permissions-url">permissions</a> can override this default method.', ['%select-cancel-method' => $this->t('Select method for cancelling account'), '%administer-users' => $this->t('Administer users'), ':permissions-url' => $this->url('user.admin_permissions')]),
Chris@0 175 ];
Chris@0 176 $form['registration_cancellation']['user_cancel_method'] += user_cancel_methods();
Chris@0 177 foreach (Element::children($form['registration_cancellation']['user_cancel_method']) as $key) {
Chris@0 178 // All account cancellation methods that specify #access cannot be
Chris@0 179 // configured as default method.
Chris@0 180 // @see hook_user_cancel_methods_alter()
Chris@0 181 if (isset($form['registration_cancellation']['user_cancel_method'][$key]['#access'])) {
Chris@0 182 $form['registration_cancellation']['user_cancel_method'][$key]['#access'] = FALSE;
Chris@0 183 }
Chris@0 184 }
Chris@0 185
Chris@0 186 // Default notifications address.
Chris@0 187 $form['mail_notification_address'] = [
Chris@0 188 '#type' => 'email',
Chris@0 189 '#title' => $this->t('Notification email address'),
Chris@0 190 '#default_value' => $site_config->get('mail_notification'),
Chris@0 191 '#description' => $this->t("The email address to be used as the 'from' address for all account notifications listed below. If <em>'Visitors, but administrator approval is required'</em> is selected above, a notification email will also be sent to this address for any new registrations. Leave empty to use the default system email address <em>(%site-email).</em>", ['%site-email' => $site_config->get('mail')]),
Chris@0 192 '#maxlength' => 180,
Chris@0 193 ];
Chris@0 194
Chris@0 195 $form['email'] = [
Chris@0 196 '#type' => 'vertical_tabs',
Chris@0 197 '#title' => $this->t('Emails'),
Chris@0 198 ];
Chris@0 199 // These email tokens are shared for all settings, so just define
Chris@0 200 // the list once to help ensure they stay in sync.
Chris@0 201 $email_token_help = $this->t('Available variables are: [site:name], [site:url], [user:display-name], [user:account-name], [user:mail], [site:login-url], [site:url-brief], [user:edit-url], [user:one-time-login-url], [user:cancel-url].');
Chris@0 202
Chris@0 203 $form['email_admin_created'] = [
Chris@0 204 '#type' => 'details',
Chris@0 205 '#title' => $this->t('Welcome (new user created by administrator)'),
Chris@18 206 '#open' => $config->get('register') == UserInterface::REGISTER_ADMINISTRATORS_ONLY,
Chris@0 207 '#description' => $this->t('Edit the welcome email messages sent to new member accounts created by an administrator.') . ' ' . $email_token_help,
Chris@0 208 '#group' => 'email',
Chris@0 209 ];
Chris@0 210 $form['email_admin_created']['user_mail_register_admin_created_subject'] = [
Chris@0 211 '#type' => 'textfield',
Chris@0 212 '#title' => $this->t('Subject'),
Chris@0 213 '#default_value' => $mail_config->get('register_admin_created.subject'),
Chris@0 214 '#maxlength' => 180,
Chris@0 215 ];
Chris@0 216 $form['email_admin_created']['user_mail_register_admin_created_body'] = [
Chris@0 217 '#type' => 'textarea',
Chris@0 218 '#title' => $this->t('Body'),
Chris@0 219 '#default_value' => $mail_config->get('register_admin_created.body'),
Chris@0 220 '#rows' => 15,
Chris@0 221 ];
Chris@0 222
Chris@0 223 $form['email_pending_approval'] = [
Chris@0 224 '#type' => 'details',
Chris@0 225 '#title' => $this->t('Welcome (awaiting approval)'),
Chris@18 226 '#open' => $config->get('register') == UserInterface::REGISTER_VISITORS_ADMINISTRATIVE_APPROVAL,
Chris@0 227 '#description' => $this->t('Edit the welcome email messages sent to new members upon registering, when administrative approval is required.') . ' ' . $email_token_help,
Chris@0 228 '#group' => 'email',
Chris@0 229 ];
Chris@0 230 $form['email_pending_approval']['user_mail_register_pending_approval_subject'] = [
Chris@0 231 '#type' => 'textfield',
Chris@0 232 '#title' => $this->t('Subject'),
Chris@0 233 '#default_value' => $mail_config->get('register_pending_approval.subject'),
Chris@0 234 '#maxlength' => 180,
Chris@0 235 ];
Chris@0 236 $form['email_pending_approval']['user_mail_register_pending_approval_body'] = [
Chris@0 237 '#type' => 'textarea',
Chris@0 238 '#title' => $this->t('Body'),
Chris@0 239 '#default_value' => $mail_config->get('register_pending_approval.body'),
Chris@0 240 '#rows' => 8,
Chris@0 241 ];
Chris@0 242
Chris@0 243 $form['email_pending_approval_admin'] = [
Chris@0 244 '#type' => 'details',
Chris@0 245 '#title' => $this->t('Admin (user awaiting approval)'),
Chris@18 246 '#open' => $config->get('register') == UserInterface::REGISTER_VISITORS_ADMINISTRATIVE_APPROVAL,
Chris@0 247 '#description' => $this->t('Edit the email notifying the site administrator that there are new members awaiting administrative approval.') . ' ' . $email_token_help,
Chris@0 248 '#group' => 'email',
Chris@0 249 ];
Chris@0 250 $form['email_pending_approval_admin']['register_pending_approval_admin_subject'] = [
Chris@0 251 '#type' => 'textfield',
Chris@0 252 '#title' => $this->t('Subject'),
Chris@0 253 '#default_value' => $mail_config->get('register_pending_approval_admin.subject'),
Chris@0 254 '#maxlength' => 180,
Chris@0 255 ];
Chris@0 256 $form['email_pending_approval_admin']['register_pending_approval_admin_body'] = [
Chris@0 257 '#type' => 'textarea',
Chris@0 258 '#title' => $this->t('Body'),
Chris@0 259 '#default_value' => $mail_config->get('register_pending_approval_admin.body'),
Chris@0 260 '#rows' => 8,
Chris@0 261 ];
Chris@0 262
Chris@0 263 $form['email_no_approval_required'] = [
Chris@0 264 '#type' => 'details',
Chris@0 265 '#title' => $this->t('Welcome (no approval required)'),
Chris@18 266 '#open' => $config->get('register') == UserInterface::REGISTER_VISITORS,
Chris@0 267 '#description' => $this->t('Edit the welcome email messages sent to new members upon registering, when no administrator approval is required.') . ' ' . $email_token_help,
Chris@0 268 '#group' => 'email',
Chris@0 269 ];
Chris@0 270 $form['email_no_approval_required']['user_mail_register_no_approval_required_subject'] = [
Chris@0 271 '#type' => 'textfield',
Chris@0 272 '#title' => $this->t('Subject'),
Chris@0 273 '#default_value' => $mail_config->get('register_no_approval_required.subject'),
Chris@0 274 '#maxlength' => 180,
Chris@0 275 ];
Chris@0 276 $form['email_no_approval_required']['user_mail_register_no_approval_required_body'] = [
Chris@0 277 '#type' => 'textarea',
Chris@0 278 '#title' => $this->t('Body'),
Chris@0 279 '#default_value' => $mail_config->get('register_no_approval_required.body'),
Chris@0 280 '#rows' => 15,
Chris@0 281 ];
Chris@0 282
Chris@0 283 $form['email_password_reset'] = [
Chris@0 284 '#type' => 'details',
Chris@0 285 '#title' => $this->t('Password recovery'),
Chris@0 286 '#description' => $this->t('Edit the email messages sent to users who request a new password.') . ' ' . $email_token_help,
Chris@0 287 '#group' => 'email',
Chris@0 288 '#weight' => 10,
Chris@0 289 ];
Chris@0 290 $form['email_password_reset']['user_mail_password_reset_subject'] = [
Chris@0 291 '#type' => 'textfield',
Chris@0 292 '#title' => $this->t('Subject'),
Chris@0 293 '#default_value' => $mail_config->get('password_reset.subject'),
Chris@0 294 '#maxlength' => 180,
Chris@0 295 ];
Chris@0 296 $form['email_password_reset']['user_mail_password_reset_body'] = [
Chris@0 297 '#type' => 'textarea',
Chris@0 298 '#title' => $this->t('Body'),
Chris@0 299 '#default_value' => $mail_config->get('password_reset.body'),
Chris@0 300 '#rows' => 12,
Chris@0 301 ];
Chris@0 302
Chris@0 303 $form['email_activated'] = [
Chris@0 304 '#type' => 'details',
Chris@0 305 '#title' => $this->t('Account activation'),
Chris@0 306 '#description' => $this->t('Enable and edit email messages sent to users upon account activation (when an administrator activates an account of a user who has already registered, on a site where administrative approval is required).') . ' ' . $email_token_help,
Chris@0 307 '#group' => 'email',
Chris@0 308 ];
Chris@0 309 $form['email_activated']['user_mail_status_activated_notify'] = [
Chris@0 310 '#type' => 'checkbox',
Chris@0 311 '#title' => $this->t('Notify user when account is activated'),
Chris@0 312 '#default_value' => $config->get('notify.status_activated'),
Chris@0 313 ];
Chris@0 314 $form['email_activated']['settings'] = [
Chris@0 315 '#type' => 'container',
Chris@0 316 '#states' => [
Chris@0 317 // Hide the additional settings when this email is disabled.
Chris@0 318 'invisible' => [
Chris@0 319 'input[name="user_mail_status_activated_notify"]' => ['checked' => FALSE],
Chris@0 320 ],
Chris@0 321 ],
Chris@0 322 ];
Chris@0 323 $form['email_activated']['settings']['user_mail_status_activated_subject'] = [
Chris@0 324 '#type' => 'textfield',
Chris@0 325 '#title' => $this->t('Subject'),
Chris@0 326 '#default_value' => $mail_config->get('status_activated.subject'),
Chris@0 327 '#maxlength' => 180,
Chris@0 328 ];
Chris@0 329 $form['email_activated']['settings']['user_mail_status_activated_body'] = [
Chris@0 330 '#type' => 'textarea',
Chris@0 331 '#title' => $this->t('Body'),
Chris@0 332 '#default_value' => $mail_config->get('status_activated.body'),
Chris@0 333 '#rows' => 15,
Chris@0 334 ];
Chris@0 335
Chris@0 336 $form['email_blocked'] = [
Chris@0 337 '#type' => 'details',
Chris@0 338 '#title' => $this->t('Account blocked'),
Chris@0 339 '#description' => $this->t('Enable and edit email messages sent to users when their accounts are blocked.') . ' ' . $email_token_help,
Chris@0 340 '#group' => 'email',
Chris@0 341 ];
Chris@0 342 $form['email_blocked']['user_mail_status_blocked_notify'] = [
Chris@0 343 '#type' => 'checkbox',
Chris@0 344 '#title' => $this->t('Notify user when account is blocked'),
Chris@0 345 '#default_value' => $config->get('notify.status_blocked'),
Chris@0 346 ];
Chris@0 347 $form['email_blocked']['settings'] = [
Chris@0 348 '#type' => 'container',
Chris@0 349 '#states' => [
Chris@0 350 // Hide the additional settings when the blocked email is disabled.
Chris@0 351 'invisible' => [
Chris@0 352 'input[name="user_mail_status_blocked_notify"]' => ['checked' => FALSE],
Chris@0 353 ],
Chris@0 354 ],
Chris@0 355 ];
Chris@0 356 $form['email_blocked']['settings']['user_mail_status_blocked_subject'] = [
Chris@0 357 '#type' => 'textfield',
Chris@0 358 '#title' => $this->t('Subject'),
Chris@0 359 '#default_value' => $mail_config->get('status_blocked.subject'),
Chris@0 360 '#maxlength' => 180,
Chris@0 361 ];
Chris@0 362 $form['email_blocked']['settings']['user_mail_status_blocked_body'] = [
Chris@0 363 '#type' => 'textarea',
Chris@0 364 '#title' => $this->t('Body'),
Chris@0 365 '#default_value' => $mail_config->get('status_blocked.body'),
Chris@0 366 '#rows' => 3,
Chris@0 367 ];
Chris@0 368
Chris@0 369 $form['email_cancel_confirm'] = [
Chris@0 370 '#type' => 'details',
Chris@0 371 '#title' => $this->t('Account cancellation confirmation'),
Chris@0 372 '#description' => $this->t('Edit the email messages sent to users when they attempt to cancel their accounts.') . ' ' . $email_token_help,
Chris@0 373 '#group' => 'email',
Chris@0 374 ];
Chris@0 375 $form['email_cancel_confirm']['user_mail_cancel_confirm_subject'] = [
Chris@0 376 '#type' => 'textfield',
Chris@0 377 '#title' => $this->t('Subject'),
Chris@0 378 '#default_value' => $mail_config->get('cancel_confirm.subject'),
Chris@0 379 '#maxlength' => 180,
Chris@0 380 ];
Chris@0 381 $form['email_cancel_confirm']['user_mail_cancel_confirm_body'] = [
Chris@0 382 '#type' => 'textarea',
Chris@0 383 '#title' => $this->t('Body'),
Chris@0 384 '#default_value' => $mail_config->get('cancel_confirm.body'),
Chris@0 385 '#rows' => 3,
Chris@0 386 ];
Chris@0 387
Chris@0 388 $form['email_canceled'] = [
Chris@0 389 '#type' => 'details',
Chris@0 390 '#title' => $this->t('Account canceled'),
Chris@0 391 '#description' => $this->t('Enable and edit email messages sent to users when their accounts are canceled.') . ' ' . $email_token_help,
Chris@0 392 '#group' => 'email',
Chris@0 393 ];
Chris@0 394 $form['email_canceled']['user_mail_status_canceled_notify'] = [
Chris@0 395 '#type' => 'checkbox',
Chris@0 396 '#title' => $this->t('Notify user when account is canceled'),
Chris@0 397 '#default_value' => $config->get('notify.status_canceled'),
Chris@0 398 ];
Chris@0 399 $form['email_canceled']['settings'] = [
Chris@0 400 '#type' => 'container',
Chris@0 401 '#states' => [
Chris@0 402 // Hide the settings when the cancel notify checkbox is disabled.
Chris@0 403 'invisible' => [
Chris@0 404 'input[name="user_mail_status_canceled_notify"]' => ['checked' => FALSE],
Chris@0 405 ],
Chris@0 406 ],
Chris@0 407 ];
Chris@0 408 $form['email_canceled']['settings']['user_mail_status_canceled_subject'] = [
Chris@0 409 '#type' => 'textfield',
Chris@0 410 '#title' => $this->t('Subject'),
Chris@0 411 '#default_value' => $mail_config->get('status_canceled.subject'),
Chris@0 412 '#maxlength' => 180,
Chris@0 413 ];
Chris@0 414 $form['email_canceled']['settings']['user_mail_status_canceled_body'] = [
Chris@0 415 '#type' => 'textarea',
Chris@0 416 '#title' => $this->t('Body'),
Chris@0 417 '#default_value' => $mail_config->get('status_canceled.body'),
Chris@0 418 '#rows' => 3,
Chris@0 419 ];
Chris@0 420
Chris@0 421 return $form;
Chris@0 422 }
Chris@0 423
Chris@0 424 /**
Chris@0 425 * {@inheritdoc}
Chris@0 426 */
Chris@0 427 public function submitForm(array &$form, FormStateInterface $form_state) {
Chris@0 428 parent::submitForm($form, $form_state);
Chris@0 429
Chris@0 430 $this->config('user.settings')
Chris@0 431 ->set('anonymous', $form_state->getValue('anonymous'))
Chris@0 432 ->set('register', $form_state->getValue('user_register'))
Chris@0 433 ->set('password_strength', $form_state->getValue('user_password_strength'))
Chris@0 434 ->set('verify_mail', $form_state->getValue('user_email_verification'))
Chris@0 435 ->set('cancel_method', $form_state->getValue('user_cancel_method'))
Chris@0 436 ->set('notify.status_activated', $form_state->getValue('user_mail_status_activated_notify'))
Chris@0 437 ->set('notify.status_blocked', $form_state->getValue('user_mail_status_blocked_notify'))
Chris@0 438 ->set('notify.status_canceled', $form_state->getValue('user_mail_status_canceled_notify'))
Chris@0 439 ->save();
Chris@0 440 $this->config('user.mail')
Chris@0 441 ->set('cancel_confirm.body', $form_state->getValue('user_mail_cancel_confirm_body'))
Chris@0 442 ->set('cancel_confirm.subject', $form_state->getValue('user_mail_cancel_confirm_subject'))
Chris@0 443 ->set('password_reset.body', $form_state->getValue('user_mail_password_reset_body'))
Chris@0 444 ->set('password_reset.subject', $form_state->getValue('user_mail_password_reset_subject'))
Chris@0 445 ->set('register_admin_created.body', $form_state->getValue('user_mail_register_admin_created_body'))
Chris@0 446 ->set('register_admin_created.subject', $form_state->getValue('user_mail_register_admin_created_subject'))
Chris@0 447 ->set('register_no_approval_required.body', $form_state->getValue('user_mail_register_no_approval_required_body'))
Chris@0 448 ->set('register_no_approval_required.subject', $form_state->getValue('user_mail_register_no_approval_required_subject'))
Chris@0 449 ->set('register_pending_approval.body', $form_state->getValue('user_mail_register_pending_approval_body'))
Chris@0 450 ->set('register_pending_approval.subject', $form_state->getValue('user_mail_register_pending_approval_subject'))
Chris@0 451 ->set('register_pending_approval_admin.body', $form_state->getValue('register_pending_approval_admin_body'))
Chris@0 452 ->set('register_pending_approval_admin.subject', $form_state->getValue('register_pending_approval_admin_subject'))
Chris@0 453 ->set('status_activated.body', $form_state->getValue('user_mail_status_activated_body'))
Chris@0 454 ->set('status_activated.subject', $form_state->getValue('user_mail_status_activated_subject'))
Chris@0 455 ->set('status_blocked.body', $form_state->getValue('user_mail_status_blocked_body'))
Chris@0 456 ->set('status_blocked.subject', $form_state->getValue('user_mail_status_blocked_subject'))
Chris@0 457 ->set('status_canceled.body', $form_state->getValue('user_mail_status_canceled_body'))
Chris@0 458 ->set('status_canceled.subject', $form_state->getValue('user_mail_status_canceled_subject'))
Chris@0 459 ->save();
Chris@0 460 $this->config('system.site')
Chris@0 461 ->set('mail_notification', $form_state->getValue('mail_notification_address'))
Chris@0 462 ->save();
Chris@0 463
Chris@0 464 // Change the admin role.
Chris@0 465 if ($form_state->hasValue('user_admin_role')) {
Chris@0 466 $admin_roles = $this->roleStorage->getQuery()
Chris@0 467 ->condition('is_admin', TRUE)
Chris@0 468 ->execute();
Chris@0 469
Chris@0 470 foreach ($admin_roles as $rid) {
Chris@0 471 $this->roleStorage->load($rid)->setIsAdmin(FALSE)->save();
Chris@0 472 }
Chris@0 473
Chris@0 474 $new_admin_role = $form_state->getValue('user_admin_role');
Chris@0 475 if ($new_admin_role) {
Chris@0 476 $this->roleStorage->load($new_admin_role)->setIsAdmin(TRUE)->save();
Chris@0 477 }
Chris@0 478 }
Chris@0 479 }
Chris@0 480
Chris@0 481 }