113 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
			
		
		
	
	
			113 lines
		
	
	
		
			3.8 KiB
		
	
	
	
		
			PHP
		
	
	
<?php
 | 
						|
 | 
						|
/*
 | 
						|
 * This file is part of the Symfony package.
 | 
						|
 *
 | 
						|
 * (c) Fabien Potencier <fabien@symfony.com>
 | 
						|
 *
 | 
						|
 * For the full copyright and license information, please view the LICENSE
 | 
						|
 * file that was distributed with this source code.
 | 
						|
 */
 | 
						|
 | 
						|
namespace Symfony\Component\VarDumper\Command;
 | 
						|
 | 
						|
use Symfony\Component\Console\Attribute\AsCommand;
 | 
						|
use Symfony\Component\Console\Command\Command;
 | 
						|
use Symfony\Component\Console\Completion\CompletionInput;
 | 
						|
use Symfony\Component\Console\Completion\CompletionSuggestions;
 | 
						|
use Symfony\Component\Console\Exception\InvalidArgumentException;
 | 
						|
use Symfony\Component\Console\Input\InputInterface;
 | 
						|
use Symfony\Component\Console\Input\InputOption;
 | 
						|
use Symfony\Component\Console\Output\OutputInterface;
 | 
						|
use Symfony\Component\Console\Style\SymfonyStyle;
 | 
						|
use Symfony\Component\VarDumper\Cloner\Data;
 | 
						|
use Symfony\Component\VarDumper\Command\Descriptor\CliDescriptor;
 | 
						|
use Symfony\Component\VarDumper\Command\Descriptor\DumpDescriptorInterface;
 | 
						|
use Symfony\Component\VarDumper\Command\Descriptor\HtmlDescriptor;
 | 
						|
use Symfony\Component\VarDumper\Dumper\CliDumper;
 | 
						|
use Symfony\Component\VarDumper\Dumper\HtmlDumper;
 | 
						|
use Symfony\Component\VarDumper\Server\DumpServer;
 | 
						|
 | 
						|
/**
 | 
						|
 * Starts a dump server to collect and output dumps on a single place with multiple formats support.
 | 
						|
 *
 | 
						|
 * @author Maxime Steinhausser <maxime.steinhausser@gmail.com>
 | 
						|
 *
 | 
						|
 * @final
 | 
						|
 */
 | 
						|
#[AsCommand(name: 'server:dump', description: 'Start a dump server that collects and displays dumps in a single place')]
 | 
						|
class ServerDumpCommand extends Command
 | 
						|
{
 | 
						|
    private DumpServer $server;
 | 
						|
 | 
						|
    /** @var DumpDescriptorInterface[] */
 | 
						|
    private array $descriptors;
 | 
						|
 | 
						|
    public function __construct(DumpServer $server, array $descriptors = [])
 | 
						|
    {
 | 
						|
        $this->server = $server;
 | 
						|
        $this->descriptors = $descriptors + [
 | 
						|
            'cli' => new CliDescriptor(new CliDumper()),
 | 
						|
            'html' => new HtmlDescriptor(new HtmlDumper()),
 | 
						|
        ];
 | 
						|
 | 
						|
        parent::__construct();
 | 
						|
    }
 | 
						|
 | 
						|
    protected function configure(): void
 | 
						|
    {
 | 
						|
        $this
 | 
						|
            ->addOption('format', null, InputOption::VALUE_REQUIRED, sprintf('The output format (%s)', implode(', ', $this->getAvailableFormats())), 'cli')
 | 
						|
            ->setHelp(<<<'EOF'
 | 
						|
<info>%command.name%</info> starts a dump server that collects and displays
 | 
						|
dumps in a single place for debugging you application:
 | 
						|
 | 
						|
  <info>php %command.full_name%</info>
 | 
						|
 | 
						|
You can consult dumped data in HTML format in your browser by providing the <comment>--format=html</comment> option
 | 
						|
and redirecting the output to a file:
 | 
						|
 | 
						|
  <info>php %command.full_name% --format="html" > dump.html</info>
 | 
						|
 | 
						|
EOF
 | 
						|
            )
 | 
						|
        ;
 | 
						|
    }
 | 
						|
 | 
						|
    protected function execute(InputInterface $input, OutputInterface $output): int
 | 
						|
    {
 | 
						|
        $io = new SymfonyStyle($input, $output);
 | 
						|
        $format = $input->getOption('format');
 | 
						|
 | 
						|
        if (!$descriptor = $this->descriptors[$format] ?? null) {
 | 
						|
            throw new InvalidArgumentException(sprintf('Unsupported format "%s".', $format));
 | 
						|
        }
 | 
						|
 | 
						|
        $errorIo = $io->getErrorStyle();
 | 
						|
        $errorIo->title('Symfony Var Dumper Server');
 | 
						|
 | 
						|
        $this->server->start();
 | 
						|
 | 
						|
        $errorIo->success(sprintf('Server listening on %s', $this->server->getHost()));
 | 
						|
        $errorIo->comment('Quit the server with CONTROL-C.');
 | 
						|
 | 
						|
        $this->server->listen(function (Data $data, array $context, int $clientId) use ($descriptor, $io) {
 | 
						|
            $descriptor->describe($io, $data, $context, $clientId);
 | 
						|
        });
 | 
						|
 | 
						|
        return 0;
 | 
						|
    }
 | 
						|
 | 
						|
    public function complete(CompletionInput $input, CompletionSuggestions $suggestions): void
 | 
						|
    {
 | 
						|
        if ($input->mustSuggestOptionValuesFor('format')) {
 | 
						|
            $suggestions->suggestValues($this->getAvailableFormats());
 | 
						|
        }
 | 
						|
    }
 | 
						|
 | 
						|
    private function getAvailableFormats(): array
 | 
						|
    {
 | 
						|
        return array_keys($this->descriptors);
 | 
						|
    }
 | 
						|
}
 |