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