DevelController.php

Same filename in other branches
  1. 4.x src/Controller/DevelController.php

Namespace

Drupal\devel\Controller

File

src/Controller/DevelController.php

View source
<?php

namespace Drupal\devel\Controller;

use Drupal\Core\Controller\ControllerBase;
use Drupal\Core\Entity\EntityTypeBundleInfoInterface;
use Drupal\Core\Field\FieldTypePluginManagerInterface;
use Drupal\Core\Field\FormatterPluginManager;
use Drupal\Core\Field\WidgetPluginManager;
use Drupal\Core\Theme\Registry;
use Drupal\Core\Url;
use Drupal\devel\DevelDumperManagerInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;

/**
 * Returns responses for devel module routes.
 */
class DevelController extends ControllerBase {
    
    /**
     * The dumper service.
     */
    protected DevelDumperManagerInterface $dumper;
    
    /**
     * The entity type bundle info service.
     */
    protected EntityTypeBundleInfoInterface $entityTypeBundleInfo;
    
    /**
     * The field type plugin manager service.
     */
    protected FieldTypePluginManagerInterface $fieldTypeManager;
    
    /**
     * The field formatter plugin manager.
     */
    protected FormatterPluginManager $formatterPluginManager;
    
    /**
     * The field widget plugin manager.
     */
    protected WidgetPluginManager $widgetPluginManager;
    
    /**
     * The theme registry.
     */
    protected Registry $themeRegistry;
    
    /**
     * {@inheritdoc}
     */
    public static function create(ContainerInterface $container) : static {
        $instance = parent::create($container);
        $instance->dumper = $container->get('devel.dumper');
        $instance->entityTypeBundleInfo = $container->get('entity_type.bundle.info');
        $instance->fieldTypeManager = $container->get('plugin.manager.field.field_type');
        $instance->formatterPluginManager = $container->get('plugin.manager.field.formatter');
        $instance->widgetPluginManager = $container->get('plugin.manager.field.widget');
        $instance->currentUser = $container->get('current_user');
        $instance->stringTranslation = $container->get('string_translation');
        $instance->themeRegistry = $container->get('theme.registry');
        $instance->entityTypeManager = $container->get('entity_type.manager');
        return $instance;
    }
    
    /**
     * Clears all caches, then redirects to the previous page.
     */
    public function cacheClear() {
        drupal_flush_all_caches();
        // @todo Use DI for messenger once https://www.drupal.org/project/drupal/issues/2940148 is resolved.
        $this->messenger()
            ->addMessage($this->t('Cache cleared.'));
        return $this->redirect('<front>');
    }
    
    /**
     * Theme registry.
     *
     * @return array
     *   The complete theme registry as renderable.
     */
    public function themeRegistry() : array {
        $hooks = $this->themeRegistry
            ->get();
        ksort($hooks);
        return $this->dumper
            ->exportAsRenderable($hooks);
    }
    
    /**
     * Builds the fields info overview page.
     *
     * @return array
     *   Array of page elements to render.
     */
    public function fieldInfoPage() {
        $fields = $this->entityTypeManager
            ->getStorage('field_storage_config')
            ->loadMultiple();
        ksort($fields);
        $output['fields'] = $this->dumper
            ->exportAsRenderable($fields, $this->t('Fields'));
        $field_instances = $this->entityTypeManager
            ->getStorage('field_config')
            ->loadMultiple();
        ksort($field_instances);
        $output['instances'] = $this->dumper
            ->exportAsRenderable($field_instances, $this->t('Instances'));
        $bundles = $this->entityTypeBundleInfo
            ->getAllBundleInfo();
        ksort($bundles);
        $output['bundles'] = $this->dumper
            ->exportAsRenderable($bundles, $this->t('Bundles'));
        $field_types = $this->fieldTypeManager
            ->getUiDefinitions();
        ksort($field_types);
        $output['field_types'] = $this->dumper
            ->exportAsRenderable($field_types, $this->t('Field types'));
        $formatter_types = $this->formatterPluginManager
            ->getDefinitions();
        ksort($formatter_types);
        $output['formatter_types'] = $this->dumper
            ->exportAsRenderable($formatter_types, $this->t('Formatter types'));
        $widget_types = $this->widgetPluginManager
            ->getDefinitions();
        ksort($widget_types);
        $output['widget_types'] = $this->dumper
            ->exportAsRenderable($widget_types, $this->t('Widget types'));
        return $output;
    }
    
    /**
     * Builds the state variable overview page.
     *
     * @return array
     *   Array of page elements to render.
     */
    public function stateSystemPage() : array {
        $can_edit = $this->currentUser
            ->hasPermission('administer site configuration');
        $header = [
            'name' => $this->t('Name'),
            'value' => $this->t('Value'),
        ];
        if ($can_edit) {
            $header['edit'] = $this->t('Operations');
        }
        $rows = [];
        // State class doesn't have getAll method so we get all states from the
        // KeyValueStorage.
        foreach ($this->keyValue('state')
            ->getAll() as $state_name => $state) {
            $rows[$state_name] = [
                'name' => [
                    'data' => $state_name,
                    'class' => 'table-filter-text-source',
                ],
                'value' => [
                    'data' => $this->dumper
                        ->export($state),
                ],
            ];
            if ($can_edit) {
                $operations['edit'] = [
                    'title' => $this->t('Edit'),
                    'url' => Url::fromRoute('devel.system_state_edit', [
                        'state_name' => $state_name,
                    ]),
                ];
                $rows[$state_name]['edit'] = [
                    'data' => [
                        '#type' => 'operations',
                        '#links' => $operations,
                    ],
                ];
            }
        }
        $output['states'] = [
            '#type' => 'devel_table_filter',
            '#filter_label' => $this->t('Search'),
            '#filter_placeholder' => $this->t('Enter state name'),
            '#filter_title' => $this->t('Enter a part of the state name to filter by.'),
            '#header' => $header,
            '#rows' => $rows,
            '#empty' => $this->t('No state variables found.'),
            '#attributes' => [
                'class' => [
                    'devel-state-list',
                ],
            ],
        ];
        return $output;
    }
    
    /**
     * Builds the session overview page.
     *
     * @return array
     *   Array of page elements to render.
     */
    public function session() {
        $output['description'] = [
            '#markup' => '<p>' . $this->t('Here are the contents of your $_SESSION variable.') . '</p>',
        ];
        $output['session'] = [
            '#type' => 'table',
            '#header' => [
                $this->t('Session name'),
                $this->t('Session ID'),
            ],
            '#rows' => [
                [
                    session_name(),
                    session_id(),
                ],
            ],
            '#empty' => $this->t('No session available.'),
        ];
        $output['data'] = $this->dumper
            ->exportAsRenderable($_SESSION);
        return $output;
    }

}

Classes

Title Deprecated Summary
DevelController Returns responses for devel module routes.