[MediapartBridge] Add new bridge (#1130)
* If no cookie session is defined, use the default rss stream * Add a parameter for enabling/disabling the single page mode
This commit is contained in:
parent
3d87ecbf8c
commit
16bd2aec7a
1 changed files with 60 additions and 0 deletions
60
bridges/MediapartBridge.php
Normal file
60
bridges/MediapartBridge.php
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
class MediapartBridge extends FeedExpander {
|
||||||
|
const MAINTAINER = 'killruana';
|
||||||
|
const NAME = 'Mediapart Bridge';
|
||||||
|
const URI = 'https://www.mediapart.fr/';
|
||||||
|
const PARAMETERS = array(
|
||||||
|
array(
|
||||||
|
'single_page_mode' => array(
|
||||||
|
'name' => 'Single page article',
|
||||||
|
'type' => 'checkbox',
|
||||||
|
'title' => 'Display long articles on a single page',
|
||||||
|
'defaultValue' => 'checked'
|
||||||
|
),
|
||||||
|
'mpsessid' => array(
|
||||||
|
'name' => 'MPSESSID',
|
||||||
|
'type' => 'text',
|
||||||
|
'title' => 'Value of the session cookie MPSESSID'
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
const CACHE_TIMEOUT = 7200; // 2h
|
||||||
|
const DESCRIPTION = 'Returns the newest articles.';
|
||||||
|
|
||||||
|
public function collectData() {
|
||||||
|
$url = self::URI . 'articles/feed';
|
||||||
|
$this->collectExpandableDatas($url);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function parseItem($newsItem) {
|
||||||
|
$item = parent::parseItem($newsItem);
|
||||||
|
|
||||||
|
// Enable single page mode?
|
||||||
|
if ($this->getInput('single_page_mode') === true) {
|
||||||
|
$item['uri'] .= '?onglet=full';
|
||||||
|
}
|
||||||
|
|
||||||
|
// If a session cookie is defined, get the full article
|
||||||
|
$mpsessid = $this->getInput('mpsessid');
|
||||||
|
if (!empty($mpsessid)) {
|
||||||
|
// Set the session cookie
|
||||||
|
$opt = array();
|
||||||
|
$opt[CURLOPT_COOKIE] = 'MPSESSID=' . $mpsessid;
|
||||||
|
|
||||||
|
// Get the page
|
||||||
|
$articlePage = getSimpleHTMLDOM(
|
||||||
|
$newsItem->link . '?onglet=full',
|
||||||
|
array(),
|
||||||
|
$opt);
|
||||||
|
|
||||||
|
// Extract the article content
|
||||||
|
$content = $articlePage->find('div.content-article', 0)->innertext;
|
||||||
|
$content = sanitize($content);
|
||||||
|
$content = defaultLinkTo($content, static::URI);
|
||||||
|
$item['content'] .= $content;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $item;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in a new issue