forked from blallo/rss-bridge
Merge pull request #304 from LogMANOriginal/DauphineLibereBridge
Dauphine libere bridge
This commit is contained in:
commit
0bb11db536
1 changed files with 116 additions and 109 deletions
|
@ -1,130 +1,137 @@
|
||||||
<?php
|
<?php
|
||||||
class DauphineLibereBridge extends BridgeAbstract{
|
class DauphineLibereBridge extends BridgeAbstract {
|
||||||
|
|
||||||
public function loadMetadatas() {
|
public function loadMetadatas() {
|
||||||
|
|
||||||
$this->maintainer = "qwertygc";
|
$this->maintainer = "qwertygc";
|
||||||
$this->name = "DauphineLibereBridge Bridge";
|
$this->name = "DauphineLibereBridge Bridge";
|
||||||
$this->uri = "http://www.ledauphine.com/";
|
$this->uri = "http://www.ledauphine.com/";
|
||||||
$this->description = "Returns the newest articles.";
|
$this->description = "Returns the newest articles.";
|
||||||
$this->update = "05/11/2015";
|
$this->update = "2016-08-02";
|
||||||
|
|
||||||
|
$this->parameters[] =
|
||||||
|
'[
|
||||||
|
{
|
||||||
|
"name" : "Catégorie de l\'article",
|
||||||
|
"identifier" : "u",
|
||||||
|
"type" : "list",
|
||||||
|
"values" : [
|
||||||
|
{
|
||||||
|
"name" : "À la une",
|
||||||
|
"value" : ""
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "France Monde",
|
||||||
|
"value" : "france-monde"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Faits Divers",
|
||||||
|
"value" : "faits-divers"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Économie et Finance",
|
||||||
|
"value" : "economie-et-finance"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Politique",
|
||||||
|
"value" : "politique"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Sport",
|
||||||
|
"value" : "sport"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Ain",
|
||||||
|
"value" : "ain"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Alpes-de-Haute-Provence",
|
||||||
|
"value" : "haute-provence"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Hautes-Alpes",
|
||||||
|
"value" : "hautes-alpes"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Ardèche",
|
||||||
|
"value" : "ardeche"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Drôme",
|
||||||
|
"value" : "drome"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Isère Sud",
|
||||||
|
"value" : "isere-sud"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Savoie",
|
||||||
|
"value" : "savoie"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Haute-Savoie",
|
||||||
|
"value" : "haute-savoie"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name" : "Vaucluse",
|
||||||
|
"value" : "vaucluse"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
]';
|
||||||
|
}
|
||||||
|
|
||||||
$this->parameters[] =
|
function ExtractContent($url, $context) {
|
||||||
'[
|
$html2 = $this->file_get_html($url, false, $context);
|
||||||
{
|
|
||||||
"name" : "Catégorie de l\'article",
|
|
||||||
"identifier" : "u",
|
|
||||||
"type" : "list",
|
|
||||||
"values" : [
|
|
||||||
{
|
|
||||||
"name" : "À la une",
|
|
||||||
"value" : ""
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "France Monde",
|
|
||||||
"value" : "france-monde"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Faits Divers",
|
|
||||||
"value" : "faits-divers"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Économie et Finance",
|
|
||||||
"value" : "economie-et-finance"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Politique",
|
|
||||||
"value" : "politique"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Sport",
|
|
||||||
"value" : "sport"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Ain",
|
|
||||||
"value" : "ain"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Alpes-de-Haute-Provence",
|
|
||||||
"value" : "haute-provence"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Hautes-Alpes",
|
|
||||||
"value" : "hautes-alpes"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Ardèche",
|
|
||||||
"value" : "ardeche"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Drôme",
|
|
||||||
"value" : "drome"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Isère Sud",
|
|
||||||
"value" : "isere-sud"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Savoie",
|
|
||||||
"value" : "savoie"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Haute-Savoie",
|
|
||||||
"value" : "haute-savoie"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name" : "Vaucluse",
|
|
||||||
"value" : "vaucluse"
|
|
||||||
}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
]';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
public function collectData(array $param){
|
|
||||||
|
|
||||||
|
|
||||||
function ExtractContent($url) {
|
|
||||||
$html2 = $this->file_get_html($url);
|
|
||||||
$text = $html2->find('div.column', 0)->innertext;
|
$text = $html2->find('div.column', 0)->innertext;
|
||||||
$text = preg_replace('@<script[^>]*?>.*?</script>@si', '', $text);
|
$text = preg_replace('@<script[^>]*?>.*?</script>@si', '', $text);
|
||||||
return $text;
|
return $text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function collectData(array $param){
|
||||||
|
|
||||||
|
// Simulate Mozilla user-agent to fix error 403 (Forbidden)
|
||||||
|
$opts = array('http' =>
|
||||||
|
array(
|
||||||
|
'method' => 'GET',
|
||||||
|
'header' => 'User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/50.0.2661.102 Safari/537.36'
|
||||||
|
)
|
||||||
|
);
|
||||||
|
|
||||||
|
$context = stream_context_create($opts);
|
||||||
|
|
||||||
if (isset($param['u'])) { /* user timeline mode */
|
if (isset($param['u'])) { /* user timeline mode */
|
||||||
$this->request = $param['u'];
|
$this->request = $param['u'];
|
||||||
$html = $this->file_get_html('http://www.ledauphine.com/'.$this->request.'/rss') or $this->returnError('Could not request DauphineLibere.', 404);
|
$html = $this->file_get_html('http://www.ledauphine.com/'.$this->request.'/rss', false, $context) or $this->returnError('Could not request DauphineLibere.', 404);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
$html = $this->file_get_html('http://www.ledauphine.com/rss') or $this->returnError('Could not request DauphineLibere.', 404);
|
$html = $this->file_get_html('http://www.ledauphine.com/rss', false, $context) or $this->returnError('Could not request DauphineLibere.', 404);
|
||||||
}
|
}
|
||||||
$limit = 0;
|
$limit = 0;
|
||||||
|
|
||||||
foreach($html->find('item') as $element) {
|
foreach($html->find('item') as $element) {
|
||||||
if($limit < 10) {
|
if($limit < 10) {
|
||||||
$item = new \Item();
|
$item = new \Item();
|
||||||
$item->title = $element->find('title', 0)->innertext;
|
$item->title = $element->find('title', 0)->innertext;
|
||||||
$item->uri = $element->find('guid', 0)->plaintext;
|
$item->uri = $element->find('guid', 0)->plaintext;
|
||||||
$item->timestamp = strtotime($element->find('pubDate', 0)->plaintext);
|
$item->timestamp = strtotime($element->find('pubDate', 0)->plaintext);
|
||||||
$item->content = ExtractContent($item->uri);
|
$item->content = $this->ExtractContent($item->uri, $context);
|
||||||
$this->items[] = $item;
|
$this->items[] = $item;
|
||||||
$limit++;
|
$limit++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
}
|
|
||||||
|
|
||||||
public function getName(){
|
public function getName(){
|
||||||
return 'Dauphine Bridge';
|
return 'Dauphine Bridge';
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getURI(){
|
public function getURI(){
|
||||||
return 'http://ledauphine.com/';
|
return 'http://ledauphine.com/';
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getCacheDuration(){
|
public function getCacheDuration(){
|
||||||
return 3600*2; // 2 hours
|
return 3600*2; // 2 hours
|
||||||
// return 0; // 2 hours
|
}
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
?>
|
Loading…
Reference in a new issue