parent
							
								
									cac7055c9d
								
							
						
					
					
						commit
						94105d829a
					
				| @ -0,0 +1,72 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace jrosset\CliProgram; | ||||
| 
 | ||||
| use jrosset\CliProgram\Monolog\ConsoleOutputWithMonolog; | ||||
| use jrosset\ExtendedMonolog\ExceptionLogger; | ||||
| use jrosset\ExtendedMonolog\LogDirectoryHandler; | ||||
| use Symfony\Component\Console\Command\Command; | ||||
| use Symfony\Component\Console\Input\InputInterface; | ||||
| use Symfony\Component\Console\Output\OutputInterface; | ||||
| 
 | ||||
| /** | ||||
|  * An application with a {@see LogDirectoryHandler Monolog log directory} for each command | ||||
|  */ | ||||
| class ApplicationWithCommandMonolog extends ApplicationWithCommandOutputInterface { | ||||
|     /** | ||||
|      * @var string The main log directory for Monolog: on subdirectory by command | ||||
|      */ | ||||
|     private string $logMainDirectory; | ||||
| 
 | ||||
|     /** | ||||
|      * Initialization | ||||
|      * | ||||
|      * @param string $logMainDirectory The main log directory for Monolog: on subdirectory by command | ||||
|      * @param string $name             The application name | ||||
|      * @param string $version          The application version | ||||
|      */ | ||||
|     public function __construct (string $logMainDirectory, string $name = 'UNKNOWN', string $version = 'UNKNOWN') { | ||||
|         parent::__construct($name, $version); | ||||
|         $this->setLogMainDirectory($logMainDirectory); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @inheritDoc | ||||
|      */ | ||||
|     protected function getOutputInterfaceForCommand (Command $command, InputInterface $input, OutputInterface $output): OutputInterface { | ||||
|         return new ConsoleOutputWithMonolog( | ||||
|             new ExceptionLogger( | ||||
|                 $command->getName(), | ||||
|                 [ | ||||
|                     new LogDirectoryHandler( | ||||
|                         $this->getLogMainDirectory() . DIRECTORY_SEPARATOR | ||||
|                         . str_replace(':', DIRECTORY_SEPARATOR, $command->getName()) | ||||
|                     ), | ||||
|                 ] | ||||
|             ), | ||||
|             $output->getVerbosity(), | ||||
|             $output->isDecorated(), | ||||
|             $output->getFormatter() | ||||
|         ); | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * The main log directory for Monolog: on subdirectory by command | ||||
|      * | ||||
|      * @return string The main log directory for Monolog: on subdirectory by command | ||||
|      */ | ||||
|     public function getLogMainDirectory (): string { | ||||
|         return $this->logMainDirectory; | ||||
|     } | ||||
|     /** | ||||
|      * Set the main log directory for Monolog: on subdirectory by command | ||||
|      * | ||||
|      * @param string $logMainDirectory The main log directory for Monolog: on subdirectory by command | ||||
|      * | ||||
|      * @return $this | ||||
|      */ | ||||
|     public function setLogMainDirectory (string $logMainDirectory): self { | ||||
|         $this->logMainDirectory = $logMainDirectory; | ||||
|         return $this; | ||||
|     } | ||||
| } | ||||
| @ -0,0 +1,39 @@ | ||||
| <?php | ||||
| 
 | ||||
| namespace jrosset\CliProgram; | ||||
| 
 | ||||
| use Symfony\Component\Console\Application; | ||||
| use Symfony\Component\Console\Command\Command; | ||||
| use Symfony\Component\Console\Input\InputInterface; | ||||
| use Symfony\Component\Console\Output\OutputInterface; | ||||
| use Throwable; | ||||
| 
 | ||||
| /** | ||||
|  * An application with a by-command {@see OutputInterface} | ||||
|  */ | ||||
| class ApplicationWithCommandOutputInterface extends Application { | ||||
|     /** | ||||
|      * Get the {@see OutputInterface} for a command | ||||
|      * | ||||
|      * @param Command         $command The command | ||||
|      * @param InputInterface  $input   The input | ||||
|      * @param OutputInterface $output  The existing output | ||||
|      * | ||||
|      * @return OutputInterface The output for the command | ||||
|      * | ||||
|      * @throws Throwable On error | ||||
|      * | ||||
|      * @noinspection PhpUnusedParameterInspection | ||||
|      */ | ||||
|     protected function getOutputInterfaceForCommand (Command $command, InputInterface $input, OutputInterface $output): OutputInterface { | ||||
|         return $output; | ||||
|     } | ||||
| 
 | ||||
|     /** | ||||
|      * @inheritDoc | ||||
|      * @throws Throwable | ||||
|      */ | ||||
|     protected function doRunCommand (Command $command, InputInterface $input, OutputInterface $output): int { | ||||
|         return parent::doRunCommand($command, $input, $this->getOutputInterfaceForCommand($command, $input, $output)); | ||||
|     } | ||||
| } | ||||
| @ -1 +0,0 @@ | ||||
| run.log | ||||
| @ -0,0 +1,2 @@ | ||||
| * | ||||
| !.gitignore | ||||
					Loading…
					
					
				
		Reference in New Issue
	
	 Julien Rosset
						Julien Rosset