2020-03-31 21:14:16 +02:00
|
|
|
<?php
|
2022-04-12 23:40:37 +02:00
|
|
|
|
2020-03-31 21:14:16 +02:00
|
|
|
class NordbayernBridge extends BridgeAbstract {
|
|
|
|
|
|
|
|
const MAINTAINER = 'schabi.org';
|
2021-07-01 04:21:58 +02:00
|
|
|
const NAME = 'Nordbayern';
|
2020-03-31 21:14:16 +02:00
|
|
|
const CACHE_TIMEOUT = 3600;
|
|
|
|
const URI = 'https://www.nordbayern.de';
|
2022-03-25 00:28:06 +01:00
|
|
|
const DESCRIPTION = 'Bridge for Bavarian regional news site nordbayern.de';
|
2020-03-31 21:14:16 +02:00
|
|
|
const PARAMETERS = array( array(
|
|
|
|
'region' => array(
|
|
|
|
'name' => 'region',
|
|
|
|
'type' => 'list',
|
|
|
|
'exampleValue' => 'Nürnberg',
|
|
|
|
'title' => 'Select a region',
|
|
|
|
'values' => array(
|
|
|
|
'Nürnberg' => 'nuernberg',
|
|
|
|
'Fürth' => 'fuerth',
|
2021-08-15 15:57:40 +02:00
|
|
|
'Erlangen' => 'erlangen',
|
2020-03-31 21:14:16 +02:00
|
|
|
'Altdorf' => 'altdorf',
|
|
|
|
'Ansbach' => 'ansbach',
|
|
|
|
'Bad Windsheim' => 'bad-windsheim',
|
|
|
|
'Bamberg' => 'bamberg',
|
|
|
|
'Dinkelsbühl/Feuchtwangen' => 'dinkelsbuehl-feuchtwangen',
|
|
|
|
'Feucht' => 'feucht',
|
|
|
|
'Forchheim' => 'forchheim',
|
|
|
|
'Gunzenhausen' => 'gunzenhausen',
|
|
|
|
'Hersbruck' => 'hersbruck',
|
|
|
|
'Herzogenaurach' => 'herzogenaurach',
|
2021-02-21 17:43:23 +01:00
|
|
|
'Hilpoltstein' => 'hilpoltstein',
|
2020-03-31 21:14:16 +02:00
|
|
|
'Höchstadt' => 'hoechstadt',
|
|
|
|
'Lauf' => 'lauf',
|
|
|
|
'Neumarkt' => 'neumarkt',
|
|
|
|
'Neustadt/Aisch' => 'neustadt-aisch',
|
|
|
|
'Pegnitz' => 'pegnitz',
|
|
|
|
'Roth' => 'roth',
|
|
|
|
'Rothenburg o.d.T.' => 'rothenburg-o-d-t',
|
|
|
|
'Treuchtlingen' => 'treuchtlingen',
|
|
|
|
'Weißenburg' => 'weissenburg'
|
|
|
|
)
|
|
|
|
),
|
|
|
|
'policeReports' => array(
|
|
|
|
'name' => 'Police Reports',
|
|
|
|
'type' => 'checkbox',
|
|
|
|
'exampleValue' => 'checked',
|
2021-07-01 04:21:58 +02:00
|
|
|
'title' => 'Include Police Reports',
|
2020-03-31 21:14:16 +02:00
|
|
|
)
|
|
|
|
));
|
|
|
|
|
2022-05-02 19:06:30 +02:00
|
|
|
private function getValidImage($picture) {
|
|
|
|
$img = $picture->find('img', 0);
|
|
|
|
if ($img) {
|
|
|
|
$imgUrl = $img->src;
|
2022-06-04 20:50:16 +02:00
|
|
|
if(!preg_match('#/logo-.*\.png#', $imgUrl)) {
|
2022-05-02 19:06:30 +02:00
|
|
|
return '<br><img src="' . $imgUrl . '">';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
2021-07-01 04:21:58 +02:00
|
|
|
private function getUseFullContent($rawContent) {
|
|
|
|
$content = '';
|
|
|
|
foreach($rawContent->children as $element) {
|
2022-05-08 16:37:53 +02:00
|
|
|
if(($element->tag === 'p' || $element->tag === 'h3') &&
|
|
|
|
$element->class !== 'article__teaser') {
|
2021-07-01 04:21:58 +02:00
|
|
|
$content .= $element;
|
2022-05-02 19:06:30 +02:00
|
|
|
} else if($element->tag === 'main') {
|
2021-07-01 04:21:58 +02:00
|
|
|
$content .= self::getUseFullContent($element->find('article', 0));
|
2022-05-02 19:06:30 +02:00
|
|
|
} else if($element->tag === 'header') {
|
2021-07-01 04:21:58 +02:00
|
|
|
$content .= self::getUseFullContent($element);
|
2022-05-02 19:06:30 +02:00
|
|
|
} else if($element->tag === 'div' &&
|
|
|
|
!str_contains($element->class, 'article__infobox') &&
|
|
|
|
!str_contains($element->class, 'authorinfo')) {
|
|
|
|
$content .= self::getUseFullContent($element);
|
2022-05-08 16:37:53 +02:00
|
|
|
} else if($element->tag === 'section' &&
|
2022-05-02 19:06:30 +02:00
|
|
|
(str_contains($element->class, 'article__richtext') ||
|
|
|
|
str_contains($element->class, 'article__context'))) {
|
|
|
|
$content .= self::getUseFullContent($element);
|
2022-05-08 16:37:53 +02:00
|
|
|
} else if($element->tag === 'picture') {
|
2022-05-02 19:06:30 +02:00
|
|
|
$content .= self::getValidImage($element);
|
2021-07-01 04:21:58 +02:00
|
|
|
}
|
2020-03-31 21:14:16 +02:00
|
|
|
}
|
2021-07-01 04:21:58 +02:00
|
|
|
return $content;
|
2020-03-31 21:14:16 +02:00
|
|
|
}
|
|
|
|
|
2022-06-04 20:50:16 +02:00
|
|
|
private function getTeaser($content) {
|
|
|
|
$teaser = $content->find('p[class=article__teaser]', 0);
|
|
|
|
if($teaser === null) {
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
$teaser = $teaser->plaintext;
|
|
|
|
$teaser = preg_replace('/[ ]{2,}/', ' ', $teaser);
|
|
|
|
$teaser = '<p class="article__teaser">' . $teaser . '</p>';
|
|
|
|
return $teaser;
|
|
|
|
}
|
|
|
|
|
2020-03-31 21:14:16 +02:00
|
|
|
private function handleArticle($link) {
|
|
|
|
$item = array();
|
|
|
|
$article = getSimpleHTMLDOM($link);
|
2021-07-01 04:21:58 +02:00
|
|
|
defaultLinkTo($article, self::URI);
|
2022-05-02 19:06:30 +02:00
|
|
|
$content = $article->find('article[id=article]', 0);
|
2020-03-31 21:14:16 +02:00
|
|
|
$item['uri'] = $link;
|
2022-04-12 23:40:37 +02:00
|
|
|
|
2022-06-04 20:50:16 +02:00
|
|
|
$author = $article->find('.article__author', 1);
|
|
|
|
if ($author !== null) {
|
|
|
|
$item['author'] = trim($author->plaintext);
|
2022-04-12 23:40:37 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
$createdAt = $article->find('[class=article__release]', 0);
|
|
|
|
if ($createdAt) {
|
|
|
|
$item['timestamp'] = strtotime(str_replace('Uhr', '', $createdAt->plaintext));
|
|
|
|
}
|
|
|
|
|
2022-06-04 20:50:16 +02:00
|
|
|
if ($article->find('h2', 0) === null) {
|
2021-08-25 15:08:23 +02:00
|
|
|
$item['title'] = $article->find('h3', 0)->innertext;
|
|
|
|
} else {
|
|
|
|
$item['title'] = $article->find('h2', 0)->innertext;
|
|
|
|
}
|
2020-03-31 21:14:16 +02:00
|
|
|
$item['content'] = '';
|
|
|
|
|
2022-06-04 20:50:16 +02:00
|
|
|
if ($article->find('section[class*=article__richtext]', 0) === null) {
|
2021-08-25 15:08:23 +02:00
|
|
|
$content = $article->find('div[class*=modul__teaser]', 0)
|
|
|
|
->find('p', 0);
|
|
|
|
$item['content'] .= $content;
|
|
|
|
} else {
|
2022-05-02 19:06:30 +02:00
|
|
|
$content = $article->find('article', 0);
|
2022-05-08 16:37:53 +02:00
|
|
|
// change order of article teaser in order to show it on top
|
|
|
|
// of the title image. If we didn't do this some rss programs
|
|
|
|
// would show the subtitle of the title image as teaser instead
|
|
|
|
// of the actuall article teaser.
|
2022-06-04 20:50:16 +02:00
|
|
|
$item['content'] .= self::getTeaser($content);
|
2021-08-25 15:08:23 +02:00
|
|
|
$item['content'] .= self::getUseFullContent($content);
|
|
|
|
}
|
2021-07-01 04:21:58 +02:00
|
|
|
|
2022-03-25 00:28:06 +01:00
|
|
|
// exclude police reports if desired
|
2021-07-01 04:21:58 +02:00
|
|
|
if($this->getInput('policeReports') ||
|
2021-10-30 01:06:04 +05:00
|
|
|
!str_contains($item['content'], 'Hier geht es zu allen aktuellen Polizeimeldungen.')) {
|
2021-07-01 04:21:58 +02:00
|
|
|
$this->items[] = $item;
|
2020-03-31 21:14:16 +02:00
|
|
|
}
|
2021-07-01 04:21:58 +02:00
|
|
|
|
2020-03-31 21:14:16 +02:00
|
|
|
$article->clear();
|
|
|
|
}
|
|
|
|
|
2021-07-01 04:21:58 +02:00
|
|
|
private function handleNewsblock($listSite) {
|
|
|
|
$main = $listSite->find('main', 0);
|
|
|
|
foreach($main->find('article') as $article) {
|
2022-04-12 23:40:37 +02:00
|
|
|
$url = $article->find('a', 0)->href;
|
|
|
|
$url = urljoin(self::URI, $url);
|
|
|
|
self::handleArticle($url);
|
2020-03-31 21:14:16 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function collectData() {
|
|
|
|
$region = $this->getInput('region');
|
2021-07-01 04:21:58 +02:00
|
|
|
if($region === 'rothenburg-o-d-t') {
|
|
|
|
$region = 'rothenburg-ob-der-tauber';
|
|
|
|
}
|
2022-04-12 23:40:37 +02:00
|
|
|
$url = self::URI . '/region/' . $region;
|
|
|
|
$listSite = getSimpleHTMLDOM($url);
|
2020-03-31 21:14:16 +02:00
|
|
|
|
2021-07-01 04:21:58 +02:00
|
|
|
self::handleNewsblock($listSite);
|
2020-03-31 21:14:16 +02:00
|
|
|
}
|
|
|
|
}
|