2019-03-23 16:22:44 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class HeiseBridge extends FeedExpander
|
|
|
|
{
|
|
|
|
const MAINTAINER = 'Dreckiger-Dan';
|
|
|
|
const NAME = 'Heise Online Bridge';
|
|
|
|
const URI = 'https://heise.de/';
|
|
|
|
const CACHE_TIMEOUT = 1800; // 30min
|
|
|
|
const DESCRIPTION = 'Returns the full articles instead of only the intro';
|
|
|
|
const PARAMETERS = [[
|
|
|
|
'category' => [
|
|
|
|
'name' => 'Category',
|
|
|
|
'type' => 'list',
|
|
|
|
'values' => [
|
|
|
|
'Alle News'
|
|
|
|
=> 'https://www.heise.de/newsticker/heise-atom.xml',
|
|
|
|
'Top-News'
|
|
|
|
=> 'https://www.heise.de/newsticker/heise-top-atom.xml',
|
|
|
|
'Internet-Störungen'
|
|
|
|
=> 'https://www.heise.de/netze/netzwerk-tools/imonitor-internet-stoerungen/feed/aktuelle-meldungen/',
|
|
|
|
'Alle News von heise Developer'
|
|
|
|
=> 'https://www.heise.de/developer/rss/news-atom.xml'
|
2022-07-01 15:10:30 +02:00
|
|
|
]
|
2019-03-23 16:22:44 +01:00
|
|
|
],
|
|
|
|
'limit' => [
|
|
|
|
'name' => 'Limit',
|
|
|
|
'type' => 'number',
|
|
|
|
'required' => false,
|
|
|
|
'title' => 'Specify number of full articles to return',
|
|
|
|
'defaultValue' => 5
|
2022-07-01 15:10:30 +02:00
|
|
|
]
|
2019-03-23 16:22:44 +01:00
|
|
|
]];
|
|
|
|
const LIMIT = 5;
|
|
|
|
|
|
|
|
public function collectData()
|
|
|
|
{
|
|
|
|
$this->collectExpandableDatas(
|
|
|
|
$this->getInput('category'),
|
|
|
|
$this->getInput('limit') ?: static::LIMIT
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function parseItem($feedItem)
|
|
|
|
{
|
|
|
|
$item = parent::parseItem($feedItem);
|
2022-02-24 19:41:42 +01:00
|
|
|
$item['uri'] = explode('?', $item['uri'])[0] . '?seite=all';
|
2019-03-23 16:22:44 +01:00
|
|
|
|
2022-03-26 02:30:21 +01:00
|
|
|
if (strpos($item['uri'], 'https://www.heise.de') !== 0) {
|
|
|
|
return $item;
|
|
|
|
}
|
|
|
|
|
2022-02-24 19:41:42 +01:00
|
|
|
$article = getSimpleHTMLDOMCached($item['uri']);
|
2019-03-23 16:22:44 +01:00
|
|
|
|
2020-11-10 07:14:09 +01:00
|
|
|
if ($article) {
|
2022-02-24 19:41:42 +01:00
|
|
|
$article = defaultLinkTo($article, $item['uri']);
|
2020-11-10 07:14:09 +01:00
|
|
|
$item = $this->addArticleToItem($item, $article);
|
|
|
|
}
|
2019-03-23 16:22:44 +01:00
|
|
|
|
|
|
|
return $item;
|
|
|
|
}
|
|
|
|
|
|
|
|
private function addArticleToItem($item, $article)
|
|
|
|
{
|
2022-09-21 21:31:43 +02:00
|
|
|
// relink URIs, as the previous a-img tags weren't recognized by this function
|
|
|
|
$article = defaultLinkTo($article, $item['uri']);
|
|
|
|
|
|
|
|
// remove unwanted stuff
|
2023-01-17 17:01:09 +01:00
|
|
|
foreach ($article->find('figure.branding, a-ad, div.ho-text, a-img, .opt-in__content-container') as $element) {
|
2022-09-21 21:31:43 +02:00
|
|
|
$element->remove();
|
|
|
|
}
|
|
|
|
// reload html, as remove() is buggy
|
|
|
|
$article = str_get_html($article->outertext);
|
|
|
|
|
|
|
|
$header = $article->find('header.a-article-header', 0);
|
2022-10-27 19:59:45 +02:00
|
|
|
if ($header) {
|
2023-01-17 17:01:09 +01:00
|
|
|
$headerElements = $header->find('p, figure img, noscript img');
|
2022-10-27 19:59:45 +02:00
|
|
|
$item['content'] = implode('', $headerElements);
|
2022-09-21 21:31:43 +02:00
|
|
|
|
2022-10-27 19:59:45 +02:00
|
|
|
$authors = $header->find('.a-creator__names .a-creator__name');
|
|
|
|
if ($authors) {
|
|
|
|
$item['author'] = implode(', ', array_map(function ($e) {
|
|
|
|
return $e->plaintext;
|
|
|
|
}, $authors));
|
|
|
|
}
|
2022-07-01 15:10:30 +02:00
|
|
|
}
|
2019-03-23 16:22:44 +01:00
|
|
|
|
2022-09-21 21:31:43 +02:00
|
|
|
$content = $article->find('.article-content', 0);
|
2022-10-27 19:59:45 +02:00
|
|
|
if ($content) {
|
|
|
|
$contentElements = $content->find(
|
2023-01-17 17:01:09 +01:00
|
|
|
'p, h3, ul, table, pre, noscript img, a-bilderstrecke h2, a-bilderstrecke figure, a-bilderstrecke figcaption'
|
2022-10-27 19:59:45 +02:00
|
|
|
);
|
|
|
|
$item['content'] .= implode('', $contentElements);
|
2023-01-17 21:21:32 +01:00
|
|
|
}
|
2019-03-23 16:22:44 +01:00
|
|
|
|
|
|
|
return $item;
|
|
|
|
}
|
|
|
|
}
|