summaryrefslogtreecommitdiff
path: root/plugins/af_comics/filters/af_comics_comicpress.php
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2014-02-17 13:00:25 +0400
committerAndrew Dolgov <[email protected]>2014-02-17 13:00:25 +0400
commit901dd67a1a756f5c4e03cc452c40b39584184474 (patch)
tree669d3b136f6ae0cf82f753b801163b29e27a7b14 /plugins/af_comics/filters/af_comics_comicpress.php
parentbf5e77a16531ba2177486ec1cdd43f87fed735f6 (diff)
af_comics: split filters to separate files to ease maintenance
Diffstat (limited to 'plugins/af_comics/filters/af_comics_comicpress.php')
-rw-r--r--plugins/af_comics/filters/af_comics_comicpress.php50
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;
+ }
+}
+?>