123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Framework;
- use Magento\Framework\Shell\CommandRendererInterface;
- /**
- * Shell command line wrapper encapsulates command execution and arguments escaping
- */
- class Shell implements ShellInterface
- {
- /**
- * Logger instance
- *
- * @var \Psr\Log\LoggerInterface
- */
- protected $logger;
- /**
- * @var CommandRendererInterface
- */
- private $commandRenderer;
- /**
- * @param CommandRendererInterface $commandRenderer
- * @param \Psr\Log\LoggerInterface $logger Logger instance to be used to log commands and their output
- */
- public function __construct(
- CommandRendererInterface $commandRenderer,
- \Psr\Log\LoggerInterface $logger = null
- ) {
- $this->logger = $logger;
- $this->commandRenderer = $commandRenderer;
- }
- /**
- * Execute a command through the command line, passing properly escaped arguments, and return its output
- *
- * @param string $command Command with optional argument markers '%s'
- * @param string[] $arguments Argument values to substitute markers with
- * @return string Output of an executed command
- * @throws \Magento\Framework\Exception\LocalizedException If a command returns non-zero exit code
- */
- public function execute($command, array $arguments = [])
- {
- $command = $this->commandRenderer->render($command, $arguments);
- $this->log($command);
- $disabled = explode(',', str_replace(' ', ',', ini_get('disable_functions')));
- if (in_array('exec', $disabled)) {
- throw new Exception\LocalizedException(new \Magento\Framework\Phrase('The exec function is disabled.'));
- }
- exec($command, $output, $exitCode);
- $output = implode(PHP_EOL, $output);
- $this->log($output);
- if ($exitCode) {
- $commandError = new \Exception($output, $exitCode);
- throw new Exception\LocalizedException(
- new \Magento\Framework\Phrase("Command returned non-zero exit code:\n`%1`", [$command]),
- $commandError
- );
- }
- return $output;
- }
- /**
- * Log a message, if a logger is specified
- *
- * @param string $message
- * @return void
- */
- protected function log($message)
- {
- if ($this->logger) {
- $this->logger->info($message);
- }
- }
- }
|