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("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->log($message, \Zend_Log::INFO); } } }