class Settings in Instagram API 8
Implements the Instagram api Settings form.
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\instagram_api\Form\Settings
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
Expanded class hierarchy of Settings
See also
1 string reference to 'Settings'
File
- src/
Form/ Settings.php, line 18
Namespace
Drupal\instagram_api\FormView source
class Settings extends ConfigFormBase {
/**
* The date formatter service.
*
* @var \Drupal\Core\Datetime\DateFormatterInterface
*/
protected $dateFormatter;
/**
* Settings constructor.
*
* @param \Drupal\Core\Config\ConfigFactoryInterface $config_factory
* Config Factory.
* @param \Drupal\Core\Datetime\DateFormatterInterface $date_formatter
* Date Formatter.
*/
public function __construct(ConfigFactoryInterface $config_factory, DateFormatterInterface $date_formatter) {
parent::__construct($config_factory);
$this->dateFormatter = $date_formatter;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('config.factory'), $container
->get('date.formatter'));
}
/**
* {@inheritdoc}
*/
public function getFormId() {
return 'instagram_api_settings';
}
/**
* {@inheritdoc}
*/
protected function getEditableConfigNames() {
return [
'instagram_api.settings',
];
}
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state) {
$config = $this
->config('instagram_api.settings');
$form['client'] = [
'#type' => 'fieldset',
'#title' => $this
->t('Client Settings'),
];
$form['client']['help'] = [
'#type' => '#markup',
'#markup' => $this
->t('To get your Client ID, you need to register your application on @link.', [
'@link' => Link::fromTextAndUrl('https://www.instagram.com/developer/clients/manage/', Url::fromUri('https://www.instagram.com/developer/clients/manage/'))
->toString(),
]),
];
$form['client']['client_id'] = [
'#type' => 'textfield',
'#title' => $this
->t('Client ID'),
'#default_value' => $config
->get('client_id'),
];
$form['client']['client_secret'] = [
'#type' => 'textfield',
'#title' => $this
->t('Client Secret'),
'#default_value' => $config
->get('client_secret'),
];
if ($config
->get('client_id') != '' && $config
->get('client_secret') != '') {
$options = [
'attributes' => [
'target' => '_blank',
],
];
$form['client']['access_token'] = [
'#type' => 'textfield',
'#title' => $this
->t('Access Token'),
'#default_value' => $config
->get('access_token'),
'#description' => $this
->t('To get your Access Token, @link.', [
'@link' => Link::fromTextAndUrl('click here', Url::fromUri($this
->accessUrl(), $options))
->toString(),
]),
];
}
$form['caching'] = [
'#type' => 'details',
'#title' => $this
->t('Instagram API Caching'),
'#open' => TRUE,
'#description' => $this
->t('API caching is recommended for all websites.'),
];
// Identical options to the ones for block caching.
// @see \Drupal\Core\Block\BlockBase::buildConfigurationForm()
$period = [
0,
60,
180,
300,
600,
900,
1800,
2700,
3600,
10800,
21600,
32400,
43200,
86400,
];
$period = array_map([
$this->dateFormatter,
'formatInterval',
], array_combine($period, $period));
$period[0] = '<' . $this
->t('no caching') . '>';
$form['caching']['api_cache_maximum_age'] = [
'#type' => 'select',
'#title' => $this
->t('API cache maximum age'),
'#default_value' => $config
->get('api_cache_maximum_age'),
'#options' => $period,
'#description' => $this
->t('The maximum time a API request can be cached by Drupal.'),
];
return parent::buildForm($form, $form_state);
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
$this
->config('instagram_api.settings')
->set('client_id', $form_state
->getValue('client_id'))
->set('client_secret', $form_state
->getValue('client_secret'))
->set('access_token', $form_state
->getValue('access_token'))
->set('api_cache_maximum_age', $form_state
->getValue('api_cache_maximum_age'))
->save();
parent::submitForm($form, $form_state);
}
/**
* Generate the Access Url.
*
* @return string
* URL.
*/
private function accessUrl() {
$config = $this
->config('instagram_api.settings');
$redirectUrl = Url::fromUri('internal:/instagram_api/callback', [
'absolute' => TRUE,
])
->toString();
$urlBase = $config
->get('api_uri') . 'authorize';
$query = [
'client_id' => $config
->get('client_id'),
'response_type' => 'code',
'redirect_uri' => $redirectUrl,
];
$url = Url::fromUri($urlBase, [
'query' => $query,
'absolute' => TRUE,
])
->toString();
return $url;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
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. | |
Settings:: |
protected | property | The date formatter service. | |
Settings:: |
private | function | Generate the Access Url. | |
Settings:: |
public | function |
Form constructor. Overrides ConfigFormBase:: |
|
Settings:: |
public static | function |
Instantiates a new instance of this class. Overrides ConfigFormBase:: |
|
Settings:: |
protected | function |
Gets the configuration names that will be editable. Overrides ConfigFormBaseTrait:: |
|
Settings:: |
public | function |
Returns a unique string identifying the form. Overrides FormInterface:: |
|
Settings:: |
public | function |
Form submission handler. Overrides ConfigFormBase:: |
|
Settings:: |
public | function |
Settings constructor. Overrides ConfigFormBase:: |
|
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. |