public function SecureLoginConfigForm::buildForm in Secure Login 8
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/ SecureLoginConfigForm.php, line 64
Class
- SecureLoginConfigForm
- Implements a SecureLogin Config form.
Namespace
Drupal\securelogin\FormCode
public function buildForm(array $form, FormStateInterface $form_state) {
global $base_secure_url;
$config = $this
->config('securelogin.settings');
$notice = $this
->t('Must be checked to enforce secure authenticated sessions.');
$states = [
'invisible' => [
':input[name="all_forms"]' => [
'checked' => TRUE,
],
],
];
$form['base_url'] = [
'#type' => 'textfield',
'#title' => $this
->t('Secure base URL'),
'#default_value' => $config
->get('base_url'),
'#description' => $this
->t('The base URL for secure pages. Leave blank to allow Drupal to determine it automatically (recommended). It is not allowed to have a trailing slash; Drupal will add it for you. For example: %base_secure_url%.', [
'%base_secure_url%' => $base_secure_url,
]),
];
$form['secure_forms'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Redirect form pages to secure URL'),
'#default_value' => $config
->get('secure_forms'),
'#description' => $this
->t('If enabled, any pages containing the forms enabled below will be redirected to the secure URL. Users can be assured that they are entering their private data on a secure URL, the contents of which have not been tampered with.'),
];
$form['all_forms'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Submit all forms to secure URL'),
'#default_value' => $config
->get('all_forms'),
'#description' => $this
->t('If enabled, all forms will be submitted to the secure URL.'),
];
$form['forms'] = [
'#type' => 'fieldset',
'#title' => $this
->t('Forms'),
'#description' => $this
->t('If checked, these forms will be submitted to the secure URL. Note, some forms must be checked to enforce secure authenticated sessions.'),
'#states' => $states,
];
$form['forms']['form_user_form'] = [
'#type' => 'checkbox',
'#title' => $this
->t('User edit form'),
'#default_value' => $config
->get('form_user_form'),
];
$form['forms']['form_user_login_form'] = [
'#type' => 'checkbox',
'#title' => $this
->t('User login form'),
'#default_value' => $config
->get('form_user_login_form'),
'#description' => $notice,
];
$form['forms']['form_user_pass'] = [
'#type' => 'checkbox',
'#title' => $this
->t('User password request form'),
'#default_value' => $config
->get('form_user_pass'),
'#description' => $notice,
];
$form['forms']['form_user_pass_reset'] = [
'#type' => 'checkbox',
'#title' => $this
->t('User password reset form'),
'#default_value' => $config
->get('form_user_pass_reset'),
'#description' => $notice,
];
$form['forms']['form_user_register_form'] = [
'#type' => 'checkbox',
'#title' => $this
->t('User registration form'),
'#default_value' => $config
->get('form_user_register_form'),
'#description' => $notice,
];
$forms = [];
$this->moduleHandler
->alter('securelogin', $forms);
foreach ($forms as $id => $item) {
$form['forms']["form_{$id}"] = [
'#type' => 'checkbox',
'#title' => $item['#title'],
'#default_value' => $config
->get("form_{$id}"),
'#description' => isset($item['#description']) ? $item['#description'] : '',
];
}
$form['other_forms'] = [
'#type' => 'textfield',
'#title' => $this
->t('Other forms to secure'),
'#default_value' => $config
->get('other_forms'),
'#description' => $this
->t('List the form IDs of any other forms that you want secured, separated by a space. If the form has a base form ID, you must list the base form ID rather than the form ID.'),
'#states' => $states,
];
return parent::buildForm($form, $form_state);
}