public function UrlloginForm::buildForm in urllogin 8
Same name and namespace in other branches
- 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\FormCode
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);
}