You are here

public function UrlloginForm::buildForm in urllogin 8

Same name and namespace in other branches
  1. 2.x src/Form/UrlloginForm.php \Drupal\urllogin\Form\UrlloginForm::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/UrlloginForm.php, line 34

Class

UrlloginForm
Implements an urllgoin admin form.

Namespace

Drupal\urllogin\Form

Code

public function buildForm(array $form, FormStateInterface $form_state) {
  $config = $this
    ->config('urllogin.settings');
  $form['encryption'] = [
    '#type' => 'fieldset',
    '#title' => $this
      ->t('Encryption settings'),
    '#description' => $this
      ->t('This page contains all the settings
      for urllogin. However you will also need to add the "login via url"
      permission to the roles of all users who will use this module for logging
      in. <br /> For testing purposes, individual url login strings can be
      generated from the status page - @statusPage for details.', [
      '@statusPage' => Link::fromTextAndUrl(t('see this page'), Url::fromRoute('urllogin.status'))
        ->toString(),
    ]),
    '#collapsible' => TRUE,
    '#collapsed' => FALSE,
  ];
  $form['encryption']['urllogin_passphrase'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Pass phrase'),
    '#description' => $this
      ->t('The passphrase for encoding URL access'),
    '#default_value' => $config
      ->get('passphrase'),
    '#size' => 40,
  ];

  /*  Disable Add DB Password to passphrase
      $form['encryption']['urllogin_add_dbpass'] = array(
      '#type' => 'checkbox',
      '#title' => $this->t('Append database access string to passphrase'),
      '#description' => $this->t('Increase security by appending the database
      access string to the passphrase.
      The only disadvantage is that changing your database password will
      invalidate all currently
      issued URL access strings. The best solution is to set the password in
      settings.php.'),
      '#default_value' => $config->get('add_dbpass'),
      );
       */

  // @TODO Check if this is neccasrry with D8 config overried system
  // disable if passphrase set in settings.php
  if (isset($GLOBALS['urllogin_passphrase'])) {
    $form['encryption']['urllogin_add_dbpass']['#disabled'] = TRUE;
    $form['encryption']['urllogin_passphrase']['#disabled'] = TRUE;
    $form['encryption']['urllogin_passphrase']['#title'] = 'Passphrase (not currently used)';
    $form['encryption']['urllogin_passphrase']['#description'] = 'Passphrase has been set in settings.php and overrides this value';
  }
  $form['encryption']['urllogin_codekey'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Validation number for generating new URL login strings'),
    '#description' => $this
      ->t('A value between 0 and 2,000,000,000. Suggestion: use current date in yyyymmdd format.'),
    '#default_value' => $config
      ->get('codekey'),
    '#size' => 10,
  ];
  $form['encryption']['urllogin_codemin'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Minimum validation number allowed for valid login'),
    '#description' => $this
      ->t('A value between 0 and 2,000,000,000. Suggestion: use oldest valid date in yyyymmdd format.'),
    '#default_value' => $config
      ->get('codemin'),
    '#size' => 10,
  ];
  $form['userlist'] = [
    '#type' => 'fieldset',
    '#title' => $this
      ->t('Bulk generation of access URLs'),
    '#description' => $this
      ->t('A bulk download of all user logon strings as a tab-separated csv file can be downloaded
      by clicking and saving @link. But first set the following options (if required) and <strong><em>save the form</em></strong>.', [
      '@link' => Link::fromTextAndUrl(t('this link.'), Url::fromRoute('urllogin.user_list'))
        ->toString(),
    ]),
    '#collapsible' => TRUE,
    '#collapsed' => FALSE,
  ];
  $form['userlist']['urllogin_destination'] = [
    '#type' => 'textfield',
    '#title' => $this
      ->t('Optional destination for bulk generated links'),
    '#description' => $this
      ->t('No leading "/" e.g. blog/my_latest_article'),
    '#default_value' => $config
      ->get('destination'),
    '#size' => 50,
  ];

  // @TODO see if this applies to D8
  $form['userlist']['urllogin_useprofile'] = [
    '#type' => 'hidden',
    /* marked hidden until profiles are supported properly in D7 (see end of file) */
    '#title' => $this
      ->t('use "firstname" and "lastname" fields from profile when creating downloaded user list'),
    '#description' => $this
      ->t('Requires the profile module and the creation of fields with the exact names:
       <em>profile_firstname, profile_lastname</em>.'),
    '#default_value' => $config
      ->get('useprofile'),
  ];
  $form['actions']['#type'] = 'actions';
  $form['actions']['submit'] = [
    '#type' => 'submit',
    '#value' => $this
      ->t('Save'),
    '#button_type' => 'primary',
  ];
  return parent::buildForm($form, $form_state);
}