whoami7 - Manager
:
/
home
/
kckglobal
/
www
/
portal
/
vendor
/
phpro
/
grumphp
/
src
/
Event
/
Subscriber
/
Upload File:
files >> /home/kckglobal/www/portal/vendor/phpro/grumphp/src/Event/Subscriber/VerboseLoggerSubscriber.php
<?php declare(strict_types=1); namespace GrumPHP\Event\Subscriber; use GrumPHP\Configuration\GuessedPaths; use Monolog\Handler\StreamHandler; use Monolog\Logger; use Symfony\Component\Console\ConsoleEvents; use Symfony\Component\Console\Event\ConsoleCommandEvent; use Symfony\Component\EventDispatcher\EventSubscriberInterface; use Symfony\Component\Console\Output\OutputInterface; class VerboseLoggerSubscriber implements EventSubscriberInterface { /** * @var Logger */ private $logger; /** * @var GuessedPaths */ private $guessedPaths; public function __construct(Logger $logger, GuessedPaths $guessedPaths) { $this->logger = $logger; $this->guessedPaths = $guessedPaths; } public static function getSubscribedEvents(): array { return [ ConsoleEvents::COMMAND => ['onCommand', PHP_INT_MAX], ]; } public function onCommand(ConsoleCommandEvent $event): void { $output = $event->getOutput(); if (!$output->isVerbose()) { return; } $this->logger->pushHandler(new StreamHandler('php://stdout', Logger::DEBUG)); $this->logGuessedPaths($output); } private function logGuessedPaths(OutputInterface $output): void { $output->writeln('Config file: '. $this->guessedPaths->getConfigFile()); $output->writeln('Working dir: '. $this->guessedPaths->getWorkingDir()); $output->writeln('Project dir: '. $this->guessedPaths->getProjectDir()); $output->writeln('GIT working dir: '. $this->guessedPaths->getGitWorkingDir()); $output->writeln('GIT repository dir: '. $this->guessedPaths->getGitRepositoryDir()); $output->writeln('Bin dir: '. $this->guessedPaths->getBinDir()); $output->writeln('Composer file: '. $this->guessedPaths->getComposerFile()->getPath()); } }
Copyright ©2021 || Defacer Indonesia