mirror of
https://github.com/RSS-Bridge/rss-bridge.git
synced 2024-11-23 01:55:27 +03:00
[UrlebirdBridge] Add bridge (#2163)
This commit is contained in:
parent
ecaae735d9
commit
606972dd3c
1 changed files with 63 additions and 0 deletions
63
bridges/UrlebirdBridge.php
Normal file
63
bridges/UrlebirdBridge.php
Normal file
|
@ -0,0 +1,63 @@
|
|||
<?php
|
||||
class UrlebirdBridge extends BridgeAbstract {
|
||||
|
||||
const MAINTAINER = 'dotter-ak';
|
||||
const NAME = 'urlebird.com';
|
||||
const URI = 'https://urlebird.com/';
|
||||
const DESCRIPTION = 'Bridge for urlebird.com';
|
||||
const CACHE_TIMEOUT = 10;
|
||||
const PARAMETERS = array(
|
||||
array(
|
||||
'query' => array(
|
||||
'name' => '@username or #hashtag',
|
||||
'type' => 'text',
|
||||
'required' => true,
|
||||
'title' => '@username or #hashtag'
|
||||
)
|
||||
)
|
||||
);
|
||||
|
||||
private $title;
|
||||
|
||||
public function collectData() {
|
||||
switch($this->getInput('query')[0]) {
|
||||
default:
|
||||
returnServerError('Please, enter valid username or hashtag!');
|
||||
break;
|
||||
case '@':
|
||||
$url = 'https://urlebird.com/user/' . substr($this->getInput('query'), 1) . '/';
|
||||
break;
|
||||
case '#':
|
||||
$url = 'https://urlebird.com/hash/' . substr($this->getInput('query'), 1) . '/';
|
||||
break;
|
||||
}
|
||||
|
||||
$html = getSimpleHTMLDOM($url);
|
||||
$this->title = $html->find('title', 0)->innertext;
|
||||
$articles = $html->find('div.thumb');
|
||||
foreach ($articles as $article) {
|
||||
$item = array();
|
||||
$item['uri'] = $article->find('a', 2)->href;
|
||||
$article_content = getSimpleHTMLDOM($item['uri']);
|
||||
$item['author'] = $article->find('img', 0)->alt . ' (' .
|
||||
$article_content->find('a.user-video', 1)->innertext . ')';
|
||||
$item['title'] = $article_content->find('title', 0)->innertext;
|
||||
$item['enclosures'][] = $article_content->find('video', 0)->poster;
|
||||
$video = $article_content->find('video', 0);
|
||||
$video->autoplay = null;
|
||||
$item['content'] = $video->outertext . '<br>' .
|
||||
$article_content->find('div.music', 0) . '<br>' .
|
||||
$article_content->find('div.info2', 0)->innertext .
|
||||
'<br><br><a href="' . $article_content->find('video', 0)->src . '">Video link</a>';
|
||||
$this->items[] = $item;
|
||||
}
|
||||
}
|
||||
|
||||
public function getName() {
|
||||
return $this->title ?: parent::getName();
|
||||
}
|
||||
|
||||
public function getIcon() {
|
||||
return 'https://urlebird.com/favicon.ico';
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue