debug = $debug ?? defined('DEBUG_MODE'); } public function cd(string $dir): UnixShell { logger()->info('Entering dir: ' . $dir); $c = clone $this; $c->cd = $dir; return $c; } /** * @throws RuntimeException */ public function exec(string $cmd): UnixShell { /* @phpstan-ignore-next-line */ logger()->info(ConsoleColor::yellow('[EXEC] ') . ConsoleColor::green($cmd)); if ($this->cd !== null) { $cmd = 'cd ' . escapeshellarg($this->cd) . ' && ' . $cmd; } if (!$this->debug) { $cmd .= ' 1>/dev/null 2>&1'; } f_passthru($cmd); return $this; } public function execWithResult(string $cmd, bool $with_log = true): array { if ($with_log) { /* @phpstan-ignore-next-line */ logger()->info(ConsoleColor::blue('[EXEC] ') . ConsoleColor::green($cmd)); } else { logger()->debug('Running command with result: ' . $cmd); } exec($cmd, $out, $code); return [$code, $out]; } public function setEnv(array $env): UnixShell { $this->env = array_merge($this->env, $env); return $this; } public function execWithEnv(string $cmd): UnixShell { return $this->exec($this->getEnvString() . ' ' . $cmd); } private function getEnvString(): string { $str = ''; foreach ($this->env as $k => $v) { $str .= ' ' . $k . '="' . $v . '"'; } return trim($str); } }