Merge branch 'WebfailBridge' of https://github.com/logmanoriginal/rss-bridge
This commit is contained in:
commit
95bd44e3fb
1 changed files with 134 additions and 0 deletions
134
bridges/WebfailBridge.php
Normal file
134
bridges/WebfailBridge.php
Normal file
|
@ -0,0 +1,134 @@
|
||||||
|
<?php
|
||||||
|
class WebfailBridge extends BridgeAbstract {
|
||||||
|
const MAINTAINER = 'logmanoriginal';
|
||||||
|
const URI = 'https://webfail.com';
|
||||||
|
const NAME = 'Webfail';
|
||||||
|
const DESCRIPTION = 'Returns the latest fails';
|
||||||
|
const PARAMETERS = array(
|
||||||
|
'By content type' => array(
|
||||||
|
'language' => array(
|
||||||
|
'name' => 'Language',
|
||||||
|
'type' => 'list',
|
||||||
|
'title' => 'Select your language',
|
||||||
|
'values' => array(
|
||||||
|
'English' => 'en',
|
||||||
|
'German' => 'de'
|
||||||
|
),
|
||||||
|
'defaultValue' => 'English'
|
||||||
|
),
|
||||||
|
'type' => array(
|
||||||
|
'name' => 'Type',
|
||||||
|
'type' => 'list',
|
||||||
|
'title' => 'Select your content type',
|
||||||
|
'values' => array(
|
||||||
|
'None' => '/',
|
||||||
|
'Facebook' => '/ffdts',
|
||||||
|
'Images' => '/images',
|
||||||
|
'Videos' => '/videos',
|
||||||
|
'Gifs' => '/gifs'
|
||||||
|
),
|
||||||
|
'defaultValue' => 'None'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
public function getURI(){
|
||||||
|
if(is_null($this->getInput('language')))
|
||||||
|
return self::URI;
|
||||||
|
|
||||||
|
// e.g.: https://en.webfail.com
|
||||||
|
return 'https://' . $this->getInput('language') . '.webfail.com';
|
||||||
|
}
|
||||||
|
|
||||||
|
public function collectData(){
|
||||||
|
$html = getSimpleHTMLDOM($this->getURI() . $this->getInput('type'));
|
||||||
|
|
||||||
|
$type = array_search($this->getInput('type')
|
||||||
|
, self::PARAMETERS[$this->queriedContext]['type']['values']);
|
||||||
|
|
||||||
|
switch(strtolower($type)){
|
||||||
|
case 'facebook':
|
||||||
|
case 'videos':
|
||||||
|
$this->ExtractNews($html, $type);
|
||||||
|
break;
|
||||||
|
case 'none':
|
||||||
|
case 'images':
|
||||||
|
case 'gifs':
|
||||||
|
$this->ExtractArticle($html);
|
||||||
|
break;
|
||||||
|
default: returnClientError('Unknown type: ' . $type);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function ExtractNews($html, $type){
|
||||||
|
$news = $html->find('#main', 0)->find('a.wf-list-news');
|
||||||
|
foreach($news as $element){
|
||||||
|
$item = array();
|
||||||
|
$item['title'] = $element->find('div.wf-news-title', 0)->innertext;
|
||||||
|
$item['uri'] = $this->getURI() . $element->href;
|
||||||
|
|
||||||
|
$img = $element->find('img.wf-image', 0)->src;
|
||||||
|
// Load high resolution image for 'facebook'
|
||||||
|
switch(strtolower($type)){
|
||||||
|
case 'facebook':
|
||||||
|
$img = $this->getImageHiResUri($item['uri']);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
}
|
||||||
|
|
||||||
|
$description = '';
|
||||||
|
if(!is_null($element->find('div.wf-news-description', 0))){
|
||||||
|
$description = $element->find('div.wf-news-description', 0)->innertext;
|
||||||
|
}
|
||||||
|
|
||||||
|
$item['content'] = '<p>'
|
||||||
|
. $description
|
||||||
|
. '</p><br><a href="'
|
||||||
|
. $item['uri']
|
||||||
|
. '"><img src="'
|
||||||
|
. $img
|
||||||
|
. '"></a>';
|
||||||
|
|
||||||
|
$this->items[] = $item;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function ExtractArticle($html){
|
||||||
|
$articles = $html->find('article');
|
||||||
|
foreach($articles as $article){
|
||||||
|
$item = array();
|
||||||
|
$item['title'] = $article->find('a', 1)->innertext;
|
||||||
|
|
||||||
|
// Webfail shares videos or images
|
||||||
|
if(!is_null($article->find('img.wf-image', 0))){ // Image type
|
||||||
|
$item['uri'] = $this->getURI() . $article->find('a', 2)->href;
|
||||||
|
$item['content'] = '<a href="'
|
||||||
|
. $item['uri']
|
||||||
|
. '"><img src="'
|
||||||
|
. $article->find('img.wf-image', 0)->src
|
||||||
|
. '">';
|
||||||
|
} elseif(!is_null($article->find('div.wf-video', 0))){ // Video type
|
||||||
|
$videoId = $this->getVideoId($article->find('div.wf-play', 0)->onclick);
|
||||||
|
$item['uri'] = 'https://youtube.com/watch?v=' . $videoId;
|
||||||
|
$item['content'] = '<a href="'
|
||||||
|
. $item['uri']
|
||||||
|
. '"><img src="http://img.youtube.com/vi/'
|
||||||
|
. $videoId
|
||||||
|
. '/0.jpg"></a>';
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->items[] = $item;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getVideoId($onclick){
|
||||||
|
return substr($onclick, 21, 11);
|
||||||
|
}
|
||||||
|
|
||||||
|
private function getImageHiResUri($url){
|
||||||
|
// https://de.webfail.com/ef524fae509?tag=ffdt
|
||||||
|
// http://cdn.webfail.com/upl/img/ef524fae509/post2.jpg
|
||||||
|
$id = substr($url, strrpos($url, '/') + 1, strlen($url) - strrpos($url, '?') + 2);
|
||||||
|
return 'http://cdn.webfail.com/upl/img/' . $id . '/post2.jpg';
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue