Merge pull request #110 from kranack/master

Update DilbertBridge
This commit is contained in:
Mitsu 2015-01-30 18:54:45 +01:00
commit fcda5403c1
2 changed files with 40 additions and 40 deletions

View file

@ -1,27 +1,26 @@
<?php <?php
/** /**
* *
* @name Dilbert Daily Strip * @name Dilbert Daily Strip
* @homepage http://dilbert.com/strips/ * @homepage http://dilbert.com/strips/
* @description The Unofficial Dilbert Daily Comic Strip * @description The Unofficial Dilbert Daily Comic Strip
* @update 16/10/2013 * @update 30/01/2015
* initial maintainer: superbaillot.net * initial maintainer: superbaillot.net
* @maintainer kranack
*/ */
class DilbertBridge extends BridgeAbstract{ class DilbertBridge extends BridgeAbstract{
public function collectData(array $param){ public function collectData(array $param){
$html = file_get_html('http://dilbert.com/strips/') or $this->returnError('Could not request Dilbert.', 404); $html = file_get_html('http://dilbert.com/strips/') or $this->returnError('Could not request Dilbert.', 404);
foreach($html->find('div.STR_Image') as $element) { foreach($html->find('section.comic-item') as $element) {
$comic = $element->find('img', 0);
$item = new Item(); $item = new Item();
$href = $element->find('a',0)->href; $item->uri = $element->find('a',0)->href;
$item->uri = 'http://dilbert.com' . $href; $item->content = '<img src="'. $comic->src . '" alt="' . $comic->alt . '" />';
$content = str_replace('src="/', 'src="http://dilbert.com/',$element->innertext); $item->title = $comic->alt;
$content = str_replace('href="/', 'href="http://dilbert.com/',$content); $item->timestamp = strtotime($element->find('h3', 0)->plaintext);
$item->content = $content;
$time = strtotime(substr($href, (strrpos($href, "/", -10) + 1), 10));
$item->title = date("d/m/Y", $time);
$item->timestamp = $time;
$this->items[] = $item; $this->items[] = $item;
} }
} }

View file

@ -4,40 +4,41 @@
* @homepage http://memo-linux.com/ * @homepage http://memo-linux.com/
* @description Returns the 10 newest posts from MemoLinux (full text) * @description Returns the 10 newest posts from MemoLinux (full text)
* @maintainer qwertygc * @maintainer qwertygc
* @update 2014-07-07 * @update 2015-01-30
*/ */
class MemoLinuxBridge extends BridgeAbstract{ class MemoLinuxBridge extends BridgeAbstract{
public function collectData(array $param){ public function collectData(array $param){
function StripCDATA($string) { function StripCDATA($string) {
$string = str_replace('<![CDATA[', '', $string); $string = str_replace('<![CDATA[', '', $string);
$string = str_replace(']]>', '', $string); $string = str_replace(']]>', '', $string);
return $string; return $string;
} }
function ExtractContent($url) {
$html2 = file_get_html($url);
$text = $html2->find('div.post-content', 0)->innertext;
$text = preg_replace('@<script[^>]*?>.*?</script>@si', '', $text);
$text = preg_replace('@<div[^>]*?>.*?</div>@si', '', $text);
$text = preg_replace("/<h1.*/", '', $text);
return $text;
}
$html = file_get_html('http://memo-linux.com/feed/') or $this->returnError('Could not request MemoLinux.', 404);
$limit = 0;
foreach($html->find('item') as $element) { function ExtractContent($url) {
if($limit < 10) { $html2 = file_get_html($url);
$item = new \Item(); $text = $html2->find('div.entry-content', 0)->innertext;
$item->title = StripCDATA($element->find('title', 0)->innertext); $text = preg_replace('@<script[^>]*?>.*?</script>@si', '', $text);
$item->uri = StripCDATA($element->find('guid', 0)->plaintext); $text = preg_replace('@<div[^>]*?>.*?</div>@si', '', $text);
$item->timestamp = strtotime($element->find('pubDate', 0)->plaintext); $text = preg_replace("/<h1.*/", '', $text);
$item->content = ExtractContent($item->uri); return $text;
$this->items[] = $item; }
$limit++;
} $html = file_get_html('http://memo-linux.com/feed/') or $this->returnError('Could not request MemoLinux.', 404);
} $limit = 0;
foreach($html->find('item') as $element) {
if($limit < 10) {
$item = new \Item();
$item->title = StripCDATA($element->find('title', 0)->innertext);
$item->uri = StripCDATA($element->find('guid', 0)->plaintext);
$item->timestamp = strtotime($element->find('pubDate', 0)->plaintext);
$item->content = ExtractContent($item->uri);
$this->items[] = $item;
$limit++;
}
}
} }
public function getName(){ public function getName(){