[RadioMelodieBridge] Update to support new Website (#1101)

* [RadioMelodieBridge] Update to support new Website
This commit is contained in:
sysadminstory 2019-04-20 22:19:22 +02:00 committed by Teromene
parent 7b8dd93a8e
commit f9c4a84c25

View file

@ -1,34 +1,88 @@
<?php <?php
class RadioMelodieBridge extends BridgeAbstract { class RadioMelodieBridge extends BridgeAbstract {
const NAME = 'Radio Melodie Actu'; const NAME = 'Radio Melodie Actu';
const URI = 'https://www.radiomelodie.com/'; const URI = 'https://www.radiomelodie.com';
const DESCRIPTION = 'Retourne les actualités publiées par Radio Melodie'; const DESCRIPTION = 'Retourne les actualités publiées par Radio Melodie';
const MAINTAINER = 'sysadminstory'; const MAINTAINER = 'sysadminstory';
public function getIcon() { public function getIcon() {
return self::URI . 'img/favicon.png'; return self::URI . '/img/favicon.png';
} }
public function collectData(){ public function collectData(){
$html = getSimpleHTMLDOM(self::URI . 'actu') $html = getSimpleHTMLDOM(self::URI . '/actu/')
or returnServerError('Could not request Radio Melodie.'); or returnServerError('Could not request Radio Melodie.');
$list = $html->find('div[class=actuitem]'); $list = $html->find('div[class=actu_col1]', 0)->children();;
foreach($list as $element) { foreach($list as $element) {
$item = array(); if($element->tag == 'a') {
$articleURL = self::URI . $element->href;
$article = getSimpleHTMLDOM($articleURL);
// Get picture URL // Initialise arrays
$pictureHTML = $element->find('div[class=picture]'); $item = array();
preg_match( $audio = array();
'/background-image:url\((.*)\);/', $picture = array();
$pictureHTML[0]->getAttribute('style'),
$pictures);
$pictureURL = $pictures[1];
$item['enclosures'] = array($pictureURL); // Get the Main picture URL
$item['uri'] = self::URI . $element->parent()->href; $picture[] = $this->rewriteImage($article->find('img[id=picturearticle]', 0)->src);
$item['title'] = $element->find('h3', 0)->plaintext; $audioHTML = $article->find('div[class=sm2-playlist-wrapper]');
$item['content'] = $element->find('p', 0)->plaintext . '<br/><img src="' . $pictureURL . '"/>';
$this->items[] = $item; // Remove the audio placeholder under the Audio player with an <audio>
// element and add the audio element to the enclosure
foreach($audioHTML as $audioElement) {
$audioURL = $audioElement->find('a', 0)->href;
$audio[] = $audioURL;
$audioElement->outertext = '<audio controls src="' . $audioURL . '"></audio>';
$article->save();
}
// Rewrite pictures URL
$imgs = $article->find('img[src^="https://www.radiomelodie.com/image.php]');
foreach($imgs as $img) {
$img->src = $this->rewriteImage($img->src);
$article->save();
}
// Remove inline audio player HTML
$inlinePlayers = $article->find('div[class*=sm2-main-controls]');
foreach($inlinePlayers as $inlinePlayer) {
$inlinePlayer->outertext = '';
$article->save();
}
// Remove Google Ads
$ads = $article->find('div[style^=margin:25px 0; position:relative; height:auto;]');
foreach($ads as $ad) {
$ad->outertext = '';
$article->save();
}
$author = $article->find('div[id=author]', 0)->find('span', 0)->plaintext;
$item['enclosures'] = array_merge($picture, $audio);
$item['author'] = $author;
$item['uri'] = $articleURL;
$item['title'] = $article->find('meta[property=og:title]', 0)->content;
$date_category = $article->find('div[class*=date]', 0)->plaintext;
$header = $article->find('a[class=fancybox]', 0)->innertext;
$textDOM = $article->find('div[class=text_content]', 0);
$textDOM->find('div[id=author]', 0)->outertext = '';
$article->save();
$text = $textDOM->innertext;
$item['content'] = '<h1>' . $item['title'] . '</h1>' . $date_category . $header . $text;
$this->items[] = $item;
}
} }
} }
/*
* Function to rewrite image URL to use the real Image URL and not the resized one (which is very slow)
*/
private function rewriteImage($url)
{
$parts = explode('?', $url);
parse_str($parts[1], $params);
return self::URI . '/' . $params['image'];
}
} }