diff options
author | 元兒~ <[email protected]> | 2014-02-17 23:16:35 +0800 |
---|---|---|
committer | 元兒~ <[email protected]> | 2014-02-17 23:16:35 +0800 |
commit | b916161aa5888ef0c644a8e714f3a7a119c689a7 (patch) | |
tree | fb6c40ba4b81319675c32bd9b0b623744e001563 /plugins/af_comics/filters/af_comics_comicpress.php | |
parent | f3e8c805f1170f9d246badf9e318a967d2bd544d (diff) | |
parent | 901dd67a1a756f5c4e03cc452c40b39584184474 (diff) |
Merge branch 'master' of github.com:gothfox/Tiny-Tiny-RSS
Diffstat (limited to 'plugins/af_comics/filters/af_comics_comicpress.php')
-rw-r--r-- | plugins/af_comics/filters/af_comics_comicpress.php | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/plugins/af_comics/filters/af_comics_comicpress.php b/plugins/af_comics/filters/af_comics_comicpress.php new file mode 100644 index 000000000..e60b2dfe5 --- /dev/null +++ b/plugins/af_comics/filters/af_comics_comicpress.php @@ -0,0 +1,50 @@ +<?php +class Af_Comics_ComicPress extends Af_ComicFilter { + + function supported() { + return array("Buni", "Buttersafe", "Whomp!", "Happy Jar", "CSection"); + } + + function process(&$article) { + $owner_uid = $article["owner_uid"]; + + if (strpos($article["guid"], "bunicomic.com") !== FALSE || + strpos($article["guid"], "buttersafe.com") !== FALSE || + strpos($article["guid"], "whompcomic.com") !== FALSE || + strpos($article["guid"], "happyjar.com") !== FALSE || + strpos($article["guid"], "csectioncomics.com") !== FALSE) { + + if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) { + + // lol at people who block clients by user agent + // oh noes my ad revenue Q_Q + + $res = fetch_file_contents($article["link"], false, false, false, + false, false, 0, + "Mozilla/5.0 (compatible; MSIE 10.0; Windows NT 6.1; WOW64; Trident/6.0)"); + + $doc = new DOMDocument(); + @$doc->loadHTML($res); + + $basenode = false; + + if ($doc) { + $xpath = new DOMXPath($doc); + $basenode = $xpath->query('//div[@id="comic"]')->item(0); + + if ($basenode) { + $article["content"] = $doc->saveXML($basenode); + $article["plugin_data"] = "af_comics,$owner_uid:" . $article["plugin_data"]; + } + } + } else if (isset($article["stored"]["content"])) { + $article["content"] = $article["stored"]["content"]; + } + + return true; + } + + return false; + } +} +?> |