You are here

public function SettingsForm::buildForm in Session Limit 8

Same name and namespace in other branches
  1. 2.x src/Form/SettingsForm.php \Drupal\session_limit\Form\SettingsForm::buildForm()

Form constructor.

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

array The form structure.

Overrides ConfigFormBase::buildForm

File

src/Form/SettingsForm.php, line 26

Class

SettingsForm

Namespace

Drupal\session_limit\Form

Code

public function buildForm(array $form, FormStateInterface $form_state) {
  $form['session_limit_max'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default maximum number of active sessions'),
    '#default_value' => \Drupal::config('session_limit.settings')
      ->get('session_limit_max'),
    '#size' => 2,
    '#maxlength' => 3,
    '#description' => $this
      ->t('The maximum number of active sessions a user can have. 0 implies unlimited sessions.'),
  ];
  $form['session_limit_behaviour'] = [
    '#type' => 'radios',
    '#title' => $this
      ->t('When the session limit is exceeded'),
    '#default_value' => \Drupal::config('session_limit.settings')
      ->get('session_limit_behaviour'),
    '#options' => SessionLimit::getActions(),
  ];
  if (\Drupal::moduleHandler()
    ->moduleExists('masquerade')) {
    $form['session_limit_masquerade_ignore'] = [
      '#type' => 'checkbox',
      '#title' => $this
        ->t('Ignore masqueraded sessions.'),
      '#description' => $this
        ->t("When a user administrator uses the masquerade module to impersonate a different user, it won't count against the session limit counter"),
      '#default_value' => \Drupal::config('session_limit.settings')
        ->get('session_limit_masquerade_ignore'),
    ];
  }
  $form['session_limit_logged_out_message_severity'] = [
    '#type' => 'select',
    '#title' => $this
      ->t('Logged out message severity'),
    '#default_value' => \Drupal::config('session_limit.settings')
      ->get('session_limit_logged_out_message_severity'),
    '#options' => [
      'error' => $this
        ->t('Error'),
      'warning' => $this
        ->t('Warning'),
      'status' => $this
        ->t('Status'),
      '_none' => $this
        ->t('No Message'),
    ],
    '#description' => $this
      ->t('The severity of the message the user receives when they are logged out by session limit.'),
  ];
  $role_limits = \Drupal::config('session_limit.settings')
    ->get('session_limit_roles');
  $form['session_limit_roles'] = [
    '#type' => 'fieldset',
    '#title' => $this
      ->t('Role limits'),
    '#description' => $this
      ->t('Optionally, specify session limits by role.'),
  ];
  foreach (user_roles(TRUE) as $rid => $role) {
    $form['session_limit_roles'][$rid] = [
      '#type' => 'select',
      '#options' => [
        0 => $this
          ->t('Uses default'),
        SessionLimit::USER_UNLIMITED_SESSIONS => $this
          ->t('No limits'),
        1,
        2,
        3,
        4,
        5,
      ],
      '#title' => $role
        ->label(),
      '#default_value' => empty($role_limits[$rid]) ? 0 : $role_limits[$rid],
    ];
  }
  return parent::buildForm($form, $form_state);
}