mirror of
https://github.com/RSS-Bridge/rss-bridge.git
synced 2024-11-21 17:15:25 +03:00
[PriviblurBridge] Add Priviblur (Tumblr frontend) bridge (#4221)
* [PriviblurBridge] Add Priviblur (Tumblr frontend) bridge * [PriviblurBridge] prevent error if post has no tags
This commit is contained in:
parent
d379f3e575
commit
06a8896000
1 changed files with 69 additions and 0 deletions
69
bridges/PriviblurBridge.php
Normal file
69
bridges/PriviblurBridge.php
Normal file
|
@ -0,0 +1,69 @@
|
|||
<?php
|
||||
|
||||
class PriviblurBridge extends BridgeAbstract
|
||||
{
|
||||
const NAME = 'Priviblur';
|
||||
const MAINTAINER = 'phantop';
|
||||
const URI = 'https://github.com/syeopite/priviblur';
|
||||
const DESCRIPTION = 'Returns Tumblr posts from a Priviblur link';
|
||||
const PARAMETERS = [
|
||||
[
|
||||
'url' => [
|
||||
'name' => 'URL',
|
||||
'exampleValue' => 'https://priviblur.fly.dev',
|
||||
'required' => true,
|
||||
]
|
||||
]
|
||||
];
|
||||
|
||||
private $title;
|
||||
|
||||
public function collectData()
|
||||
{
|
||||
$url = $this->getURI();
|
||||
$html = getSimpleHTMLDOM($url);
|
||||
$html = defaultLinkTo($html, $url);
|
||||
$this->title = $html->find('head title', 0)->innertext;
|
||||
|
||||
$elements = $html->find('.post');
|
||||
foreach ($elements as $element) {
|
||||
$item = [];
|
||||
$item['author'] = $element->find('.primary-post-author .blog-name', 0)->innertext;
|
||||
$item['comments'] = $element->find('.interaction-buttons > a', 1)->href;
|
||||
$item['content'] = $element->find('.post-body', 0);
|
||||
$item['timestamp'] = $element->find('.primary-post-author time', 0)->innertext;
|
||||
$item['title'] = $item['author'] . ': ' . $item['timestamp'];
|
||||
$item['uid'] = $item['comments']; // tumblr url is canonical
|
||||
$item['uri'] = $element->find('.interaction-buttons > a', 0)->href;
|
||||
|
||||
if ($element->find('.post-tags', 0)) {
|
||||
$tags = html_entity_decode($element->find('.post-tags', 0)->plaintext);
|
||||
$tags = explode('#', $tags);
|
||||
$tags = array_map('trim', $tags);
|
||||
array_shift($tags);
|
||||
$item['categories'] = $tags;
|
||||
}
|
||||
|
||||
$heading = $element->find('h1', 0);
|
||||
if ($heading) {
|
||||
$item['title'] = $heading->innertext;
|
||||
}
|
||||
|
||||
$this->items[] = $item;
|
||||
}
|
||||
}
|
||||
|
||||
public function getName()
|
||||
{
|
||||
$name = parent::getName();
|
||||
if (isset($this->title)) {
|
||||
$name = $this->title;
|
||||
}
|
||||
return $name;
|
||||
}
|
||||
|
||||
public function getURI()
|
||||
{
|
||||
return $this->getInput('url') ? $this->getInput('url') : parent::getURI();
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue