You are here

public function SettingsForm::buildForm in Session Limit 2.x

Same name and namespace in other branches
  1. 8 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 66

Class

SettingsForm
Class SettingsForm.

Namespace

Drupal\session_limit\Form

Code

public function buildForm(array $form, FormStateInterface $form_state) {
  $config = $this
    ->config('session_limit.settings');
  $form['session_limit_max'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Default maximum number of active sessions'),
    '#default_value' => $config
      ->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' => $config
      ->get('session_limit_behaviour'),
    '#options' => SessionLimit::getActions(),
  ];
  if ($this->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' => $config
        ->get('session_limit_masquerade_ignore'),
    ];
  }
  $form['session_limit_logged_out_message_severity'] = [
    '#type' => 'select',
    '#title' => $this
      ->t('Logged out message severity'),
    '#default_value' => $config
      ->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 = $config
    ->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 => 1,
        2 => 2,
        3 => 3,
        4 => 4,
        5 => 5,
      ],
      '#title' => $role
        ->label(),
      '#default_value' => empty($role_limits[$rid]) ? 0 : $role_limits[$rid],
    ];
  }
  $form['session_limit_admin_inclusion'] = [
    '#type' => 'checkbox',
    '#title' => $this
      ->t('Apply session limit for (ADMIN) also'),
    '#description' => $this
      ->t("Bydefsult session limit is not working for ADMIN , but if eneble this checkbox then it will work for admin also"),
    '#default_value' => \Drupal::config('session_limit.settings')
      ->get('session_limit_admin_inclusion'),
  ];
  return parent::buildForm($form, $form_state);
}