Add a way to log commands
This commit is contained in:
parent
dfdf6fef76
commit
0413427bbe
3 changed files with 74 additions and 51 deletions
|
@ -14,6 +14,8 @@ use Alltube\Library\Exception\WrongPasswordException;
|
|||
use Alltube\Library\Exception\YoutubedlException;
|
||||
use GuzzleHttp\Client;
|
||||
use Psr\Http\Message\ResponseInterface;
|
||||
use Psr\Log\LoggerInterface;
|
||||
use Psr\Log\NullLogger;
|
||||
use Symfony\Component\Process\Process;
|
||||
|
||||
/**
|
||||
|
@ -65,6 +67,11 @@ class Downloader
|
|||
*/
|
||||
private $params;
|
||||
|
||||
/**
|
||||
* @var LoggerInterface
|
||||
*/
|
||||
private $logger;
|
||||
|
||||
/**
|
||||
* Downloader constructor.
|
||||
* @param string $youtubedl youtube-dl binary path
|
||||
|
@ -88,6 +95,17 @@ class Downloader
|
|||
$this->avconv = $avconv;
|
||||
$this->phantomjsDir = $phantomjsDir;
|
||||
$this->avconvVerbosity = $avconvVerbosity;
|
||||
|
||||
$this->logger = new NullLogger();
|
||||
}
|
||||
|
||||
/**
|
||||
* @param LoggerInterface $logger
|
||||
* @return void
|
||||
*/
|
||||
public function setLogger(LoggerInterface $logger)
|
||||
{
|
||||
$this->logger = $logger;
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -207,7 +225,10 @@ class Downloader
|
|||
$arguments[] = '-user_agent';
|
||||
$arguments[] = $video->getProp('dump-user-agent');
|
||||
|
||||
return new Process($arguments);
|
||||
$process = new Process($arguments);
|
||||
$this->logger->debug($process->getCommandLine());
|
||||
|
||||
return $process;
|
||||
}
|
||||
|
||||
|
||||
|
@ -226,6 +247,7 @@ class Downloader
|
|||
$process = $this->getProcess($arguments);
|
||||
//This is needed by the openload extractor because it runs PhantomJS
|
||||
$process->setEnv(['PATH' => $this->phantomjsDir]);
|
||||
$this->logger->debug($process->getCommandLine());
|
||||
$process->run();
|
||||
if (!$process->isSuccessful()) {
|
||||
$errorOutput = trim($process->getErrorOutput());
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue