diff --git a/bridges/AutoPodcasterBridge.php b/bridges/AutoPodcasterBridge.php index e8cabbd6..8299127f 100644 --- a/bridges/AutoPodcasterBridge.php +++ b/bridges/AutoPodcasterBridge.php @@ -1,11 +1,13 @@ [ 'url' => [ 'name' => 'URL', 'required' => true @@ -15,49 +17,56 @@ class AutoPodcasterBridge extends FeedExpander { 'type' => 'checkbox', 'required' => false, ] - )); + ]]; - private function archiveIsAudioFormat($formatString) { + private function archiveIsAudioFormat($formatString) + { return strpos($formatString, 'MP3') !== false || strpos($formatString, 'Ogg') === 0; } - private function extractAudio($dom) { + private function extractAudio($dom) + { $audios = []; - foreach($dom->find('audio') as $audioEl) { + foreach ($dom->find('audio') as $audioEl) { $sources = []; - if($audioEl->src !== false) { + if ($audioEl->src !== false) { $sources[] = $audioEl->src; } - foreach($audioEl->find('source') as $sourceEl) { + foreach ($audioEl->find('source') as $sourceEl) { $sources[] = $sourceEl->src; } - if($sources) { + if ($sources) { $audios[$sources[0]] = ['sources' => $sources]; } } return $audios; } - private function extractIframeArchive($dom) { + private function extractIframeArchive($dom) + { $audios = []; - foreach($dom->find('iframe') as $iframeEl) { - if(strpos($iframeEl->src, "https://archive.org/embed/") === 0) { - $listURL = preg_replace("/\/embed\//", "/details/", $iframeEl->src, 1) . "?output=json"; - $baseURL = preg_replace("/\/embed\//", "/download/", $iframeEl->src, 1); + foreach ($dom->find('iframe') as $iframeEl) { + if (strpos($iframeEl->src, 'https://archive.org/embed/') === 0) { + $listURL = preg_replace('/\/embed\//', '/details/', $iframeEl->src, 1) . '?output=json'; + $baseURL = preg_replace('/\/embed\//', '/download/', $iframeEl->src, 1); $list = json_decode(file_get_contents($listURL)); $audios = []; - foreach($list->files as $name =>$data) { - if($data->source === 'original' && - $this->archiveIsAudioFormat($data->format)) { + foreach ($list->files as $name => $data) { + if ( + $data->source === 'original' && + $this->archiveIsAudioFormat($data->format) + ) { $audios[$baseURL . $name] = ['sources' => [$baseURL . $name]]; } } - foreach($list->files as $name =>$data) { - if($data->source === 'derivative' && + foreach ($list->files as $name => $data) { + if ( + $data->source === 'derivative' && $this->archiveIsAudioFormat($data->format) && - isset($audios[$baseURL . "/" . $data->original])) { - $audios[$baseURL . "/" . $data->original]['sources'][] = $baseURL . $name; + isset($audios[$baseURL . '/' . $data->original]) + ) { + $audios[$baseURL . '/' . $data->original]['sources'][] = $baseURL . $name; } } } @@ -66,10 +75,11 @@ class AutoPodcasterBridge extends FeedExpander { return $audios; } - protected function parseItem($newItem){ - $item = parent::parseItem($newItem); + protected function parseItem($newItem) + { + $item = parent::parseItem($newItem); - if(! $this->getInput('feed_only')) { + if (! $this->getInput('feed_only')) { $dom = getSimpleHTMLDOMCached($item['uri']); // $dom will be false in case of errors } else { @@ -82,43 +92,46 @@ class AutoPodcasterBridge extends FeedExpander { /* 2nd extraction method: by "iframe" tag */ $audios = array_merge($audios, $this->extractIframeArchive($dom)); - } - elseif($item['content'] !== NULL) { + } elseif ($item['content'] !== null) { $item_dom = str_get_html($item['content']); /* 1st extraction method: by "audio" tag */ $audios = array_merge($audios, $this->extractAudio($item_dom)); /* 2nd extraction method: by "iframe" tag */ - $audios = array_merge($audios, - $this->extractIframeArchive($item_dom)); + $audios = array_merge( + $audios, + $this->extractIframeArchive($item_dom) + ); } - if(count($audios) === 0) { + if (count($audios) === 0) { return null; } $item['enclosures'] = []; - foreach(array_values($audios) as $audio) { + foreach (array_values($audios) as $audio) { $item['enclosures'][] = $audio['sources'][0]; } return $item; - } - public function collectData(){ - if($this->getInput('url') && substr($this->getInput('url'), 0, strlen('http')) !== 'http') { - // just in case someone find a way to access local files by playing with the url - returnClientError('The url parameter must either refer to http or https protocol.'); - } - $this->collectExpandableDatas($this->getURI()); - } - public function getName(){ - if(!is_null($this->getInput('url'))) { - return self::NAME . ' : ' . $this->getInput('url'); - } - - return parent::getName(); - } - public function getURI(){ - return $this->getInput('url'); } + public function collectData() + { + if ($this->getInput('url') && substr($this->getInput('url'), 0, strlen('http')) !== 'http') { + // just in case someone find a way to access local files by playing with the url + returnClientError('The url parameter must either refer to http or https protocol.'); + } + $this->collectExpandableDatas($this->getURI()); + } + public function getName() + { + if (!is_null($this->getInput('url'))) { + return self::NAME . ' : ' . $this->getInput('url'); + } + return parent::getName(); + } + public function getURI() + { + return $this->getInput('url'); + } }