class XFrameOptionsConfigurationSettingsForm in X-Frame-Options Configuration 8
Configure example settings for this site.
Hierarchy
- class \Drupal\Core\Form\FormBase implements ContainerInjectionInterface, FormInterface uses DependencySerializationTrait, LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
- class \Drupal\x_frame_options_configuration\Form\XFrameOptionsConfigurationSettingsForm
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
Expanded class hierarchy of XFrameOptionsConfigurationSettingsForm
1 string reference to 'XFrameOptionsConfigurationSettingsForm'
File
- src/
Form/ XFrameOptionsConfigurationSettingsForm.php, line 13
Namespace
Drupal\x_frame_options_configuration\FormView source
class XFrameOptionsConfigurationSettingsForm extends ConfigFormBase {
/**
* {@inheritdoc}
*/
public function getFormId() {
return 'x_frame_options_configuration_admin_settings';
}
/**
* {@inheritdoc}
*/
protected function getEditableConfigNames() {
return [
'x_frame_options_configuration.settings',
];
}
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state) {
$config = $this
->config('x_frame_options_configuration.settings');
// Markup to explain what the X-Frame-Options HTTP response header is.
$form['markup'] = [
'#type' => 'markup',
'#markup' => $this
->t('<h3>Description:</h3><p>The X-Frame-Options HTTP response header can be used to indicate whether or not a browser should be allowed to render a page in a <frame>, <iframe> or <object>. Sites can use this to avoid clickjacking attacks, by ensuring that their content is not embedded into other sites.</p>'),
];
/*
* Create the field that will allow users to select which directive to use
* ('DENY', 'SAMEORIGIN', 'ALLOW-FROM', 'ALLOW-ALL').
*/
$form['directive'] = [
'#type' => 'radios',
'#title' => $this
->t('Directive'),
'#default_value' => $config
->get('x_frame_options_configuration.directive', 'DENY'),
'#options' => [
'DENY' => $this
->t('DENY'),
'SAMEORIGIN' => $this
->t('SAMEORIGIN'),
'ALLOW-FROM' => $this
->t('ALLOW-FROM uri'),
'ALLOW-ALL' => $this
->t('ALLOW ALL (Remove header)'),
],
'#required' => TRUE,
];
/*
* Create the field that will allow the users to specify the URI that will
* be allowed to render this page. This field will only be visible when the
* directive field has the 'ALLOW-FROM' option checked.
*/
$form['allow-from-uri'] = [
'#type' => 'textfield',
'#title' => $this
->t('Uri (if "ALLOW-FROM uri" is selected).'),
'#default_value' => $config
->get('x_frame_options_configuration.allow-from-uri'),
'#placeholder' => $this
->t('http://domain.com/'),
'#description' => $this
->t('<strong>Use with caution because this directive might be ignored on Google Chrome or Safari and your site will allow to be rendered from anywhere</strong>.<br />Check for detailed <a href="https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/X-Frame-Options#Browser_compatibility" target="_blank">browser compatibility</a> information.'),
'#states' => [
'visible' => [
':input[name="directive"]' => [
'value' => 'ALLOW-FROM',
],
],
],
];
return parent::buildForm($form, $form_state);
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
// Retrieve the configuration.
$this->configFactory
->getEditable('x_frame_options_configuration.settings')
->set('x_frame_options_configuration.directive', Html::escape($form_state
->getValue('directive')))
->set('x_frame_options_configuration.allow-from-uri', UrlHelper::stripDangerousProtocols(Html::escape($form_state
->getValue('allow-from-uri'))))
->save();
parent::submitForm($form, $form_state);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigFormBase:: |
public static | function |
Instantiates a new instance of this class. Overrides FormBase:: |
13 |
ConfigFormBase:: |
public | function | Constructs a \Drupal\system\ConfigFormBase object. | 11 |
ConfigFormBaseTrait:: |
protected | function | Retrieves a configuration object. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
FormBase:: |
protected | property | The config factory. | 1 |
FormBase:: |
protected | property | The request stack. | 1 |
FormBase:: |
protected | property | The route match. | |
FormBase:: |
protected | function | Gets the config factory for this form. | 1 |
FormBase:: |
private | function | Returns the service container. | |
FormBase:: |
protected | function | Gets the current user. | |
FormBase:: |
protected | function | Gets the request object. | |
FormBase:: |
protected | function | Gets the route match. | |
FormBase:: |
protected | function | Gets the logger for a specific channel. | |
FormBase:: |
protected | function |
Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: |
|
FormBase:: |
public | function | Resets the configuration factory. | |
FormBase:: |
public | function | Sets the config factory for this form. | |
FormBase:: |
public | function | Sets the request stack object to use. | |
FormBase:: |
public | function |
Form validation handler. Overrides FormInterface:: |
62 |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. | |
XFrameOptionsConfigurationSettingsForm:: |
public | function |
Form constructor. Overrides ConfigFormBase:: |
|
XFrameOptionsConfigurationSettingsForm:: |
protected | function |
Gets the configuration names that will be editable. Overrides ConfigFormBaseTrait:: |
|
XFrameOptionsConfigurationSettingsForm:: |
public | function |
Returns a unique string identifying the form. Overrides FormInterface:: |
|
XFrameOptionsConfigurationSettingsForm:: |
public | function |
Form submission handler. Overrides ConfigFormBase:: |