SystemInfoController.php

Same filename in other branches
  1. 9 core/modules/system/src/Controller/SystemInfoController.php
  2. 8.9.x core/modules/system/src/Controller/SystemInfoController.php
  3. 11.x core/modules/system/src/Controller/SystemInfoController.php

Namespace

Drupal\system\Controller

File

core/modules/system/src/Controller/SystemInfoController.php

View source
<?php

namespace Drupal\system\Controller;

use Drupal\Core\Site\Settings;
use Symfony\Component\DependencyInjection\ContainerInterface;
use Symfony\Component\HttpFoundation\Response;
use Drupal\Core\DependencyInjection\ContainerInjectionInterface;
use Drupal\system\SystemManager;
use Drupal\Core\StringTranslation\StringTranslationTrait;

/**
 * Returns responses for System Info routes.
 */
class SystemInfoController implements ContainerInjectionInterface {
    use StringTranslationTrait;
    
    /**
     * System Manager Service.
     *
     * @var \Drupal\system\SystemManager
     */
    protected $systemManager;
    
    /**
     * {@inheritdoc}
     */
    public static function create(ContainerInterface $container) {
        return new static($container->get('system.manager'));
    }
    
    /**
     * Constructs a SystemInfoController object.
     *
     * @param \Drupal\system\SystemManager $systemManager
     *   System manager service.
     */
    public function __construct(SystemManager $systemManager) {
        $this->systemManager = $systemManager;
    }
    
    /**
     * Displays the site status report.
     *
     * @return array
     *   A render array containing a list of system requirements for the Drupal
     *   installation and whether this installation meets the requirements.
     */
    public function status() {
        $requirements = $this->systemManager
            ->listRequirements();
        return [
            '#type' => 'status_report_page',
            '#requirements' => $requirements,
        ];
    }
    
    /**
     * Returns the contents of phpinfo().
     *
     * @return \Symfony\Component\HttpFoundation\Response
     *   A response object to be sent to the client.
     */
    public function php() {
        if (function_exists('phpinfo')) {
            ob_start();
            $phpinfo_flags = Settings::get('sa_core_2023_004_phpinfo_flags', ~(INFO_VARIABLES | INFO_ENVIRONMENT));
            phpinfo($phpinfo_flags);
            $output = ob_get_clean();
        }
        else {
            $output = $this->t('The phpinfo() function is disabled. For more information, visit the <a href=":phpinfo">Enabling and disabling phpinfo()</a> handbook page.', [
                ':phpinfo' => 'https://www.drupal.org/node/243993',
            ]);
        }
        return new Response($output);
    }

}

Classes

Title Deprecated Summary
SystemInfoController Returns responses for System Info routes.

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.