. ' --no-playlist'//would otherwise cause multiple json blocks
. ' --quiet'
. ' --dump-json'
- . ' ' . escapeshellarg($pageUrl)
- . ' 2> /dev/null';
+ . ' ' . escapeshellarg($pageUrl);
- $lastLine = exec($cmd, $output, $exitCode);
- if ($exitCode !== 0) {
- if ($exitCode === 127) {
- errorOut(
- 'youtube-dl not found at ' . $youtubedlPath,
- '500 youtube-dl not found'
- );
- } else if (strpos($lastLine, 'Unsupported URL') !== false) {
- errorOut(
- 'Unsupported URL at ' . $pageUrl,
- '406 Unsupported URL (No video found)'
- );
- } else {
- errorOut('youtube-dl error: ' . $lastLine);
- }
+ $descriptors = [
+ 1 => ['pipe', 'w'],//stdout
+ 2 => ['pipe', 'w'],//stderr
+ ];
+ $proc = proc_open($cmd, $descriptors, $pipes);
+ if ($proc === false) {
+ errorOut('Error running youtube-dl');
}
+ $stdout = stream_get_contents($pipes[1]);
+ $stderr = stream_get_contents($pipes[2]);
+
+ $exitCode = proc_close($proc);
- $json = implode("\n", $output);
- return $json;
+ if ($exitCode === 0) {
+ //stdout contains the JSON data
+ return $stdout;
+ }
+
+ if (strlen($stderr)) {
+ $lines = explode("\n", trim($stderr));
+ $lastLine = end($lines);
+ } else {
+ $lines = explode("\n", trim($stdout));
+ $lastLine = end($lines);
+ }
+
+ if ($exitCode === 127) {
+ errorOut(
+ 'youtube-dl not found at ' . $youtubedlPath,
+ '500 youtube-dl not found'
+ );
+ } else if (strpos($lastLine, 'Unsupported URL') !== false) {
+ errorOut(
+ 'Unsupported URL at ' . $pageUrl,
+ '406 Unsupported URL (No video found)'
+ );
+ }
+
+ errorOut('youtube-dl error: ' . $lastLine);
}
function extractVideoUrlFromJson($json)
ini_set('track_errors', 1);
$xml = @file_get_contents($dreamboxUrl . '/web/session');
if ($xml === false) {
+ if (!isset($http_response_header)) {
+ errorOut(
+ 'Error fetching dreambox web interface token: '
+ . $GLOBALS['lastError']
+ );
+ }
+
list($http, $code, $message) = explode(
' ', $http_response_header[0], 3
);
);
}
}
+
+function errorHandlerStore($number, $message, $file, $line)
+{
+ $GLOBALS['lastError'] = $message;
+ return false;
+}
+$GLOBALS['lastError'] = null;
?>