summaryrefslogtreecommitdiff
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
parentbf5e77a16531ba2177486ec1cdd43f87fed735f6 (diff)
af_comics: split filters to separate files to ease maintenance
-rw-r--r--plugins/af_comics/af_comics_template.php14
-rw-r--r--plugins/af_comics/filter_base.php6
-rw-r--r--plugins/af_comics/filters/af_comics_cad.php39
-rw-r--r--plugins/af_comics/filters/af_comics_comicpress.php50
-rw-r--r--plugins/af_comics/filters/af_comics_dilbert.php52
-rw-r--r--plugins/af_comics/filters/af_comics_explosm.php49
-rw-r--r--plugins/af_comics/filters/af_comics_gocomics.php62
-rw-r--r--plugins/af_comics/filters/af_comics_pa.php89
-rw-r--r--plugins/af_comics/filters/af_comics_twp.php39
-rw-r--r--plugins/af_comics/init.php308
10 files changed, 432 insertions, 276 deletions
diff --git a/plugins/af_comics/af_comics_template.php b/plugins/af_comics/af_comics_template.php
new file mode 100644
index 000000000..117d69280
--- /dev/null
+++ b/plugins/af_comics/af_comics_template.php
@@ -0,0 +1,14 @@
+<?php
+class Af_Comics_Template extends Af_ComicFilter {
+
+ function supported() {
+ return array("Example");
+ }
+
+ function process(&$article) {
+ $owner_uid = $article["owner_uid"];
+
+ return false;
+ }
+}
+?>
diff --git a/plugins/af_comics/filter_base.php b/plugins/af_comics/filter_base.php
new file mode 100644
index 000000000..a53430645
--- /dev/null
+++ b/plugins/af_comics/filter_base.php
@@ -0,0 +1,6 @@
+<?php
+abstract class Af_ComicFilter {
+ public abstract function supported();
+ public abstract function process(&$article);
+}
+?>
diff --git a/plugins/af_comics/filters/af_comics_cad.php b/plugins/af_comics/filters/af_comics_cad.php
new file mode 100644
index 000000000..6184977d1
--- /dev/null
+++ b/plugins/af_comics/filters/af_comics_cad.php
@@ -0,0 +1,39 @@
+<?php
+class Af_Comics_Cad extends Af_ComicFilter {
+
+ function supported() {
+ return array("Ctrl+Alt+Del");
+ }
+
+ function process(&$article) {
+ $owner_uid = $article["owner_uid"];
+
+ if (strpos($article["link"], "cad-comic.com/cad/") !== FALSE) {
+ if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
+
+ $doc = new DOMDocument();
+ @$doc->loadHTML(fetch_file_contents($article["link"]));
+
+ $basenode = false;
+
+ if ($doc) {
+ $xpath = new DOMXPath($doc);
+ $basenode = $xpath->query('(//img[contains(@src, "/comics/cad-")])')->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;
+ }
+}
+?>
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;
+ }
+}
+?>
diff --git a/plugins/af_comics/filters/af_comics_dilbert.php b/plugins/af_comics/filters/af_comics_dilbert.php
new file mode 100644
index 000000000..4c2233a3a
--- /dev/null
+++ b/plugins/af_comics/filters/af_comics_dilbert.php
@@ -0,0 +1,52 @@
+<?php
+class Af_Comics_Dilbert extends Af_ComicFilter {
+
+ function supported() {
+ return array("Dilbert");
+ }
+
+ function process(&$article) {
+ $owner_uid = $article["owner_uid"];
+
+ if (strpos($article["guid"], "dilbert.com") !== FALSE) {
+ if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
+ $doc = new DOMDocument();
+ @$doc->loadHTML(fetch_file_contents($article["link"]));
+
+ $basenode = false;
+
+ if ($doc) {
+ $xpath = new DOMXPath($doc);
+ $entries = $xpath->query('(//img[@src])'); // we might also check for img[@class='strip'] I guess...
+
+ $matches = array();
+
+ foreach ($entries as $entry) {
+
+ if (preg_match("/dyn\/str_strip\/.*zoom\.gif$/", $entry->getAttribute("src"), $matches)) {
+
+ $entry->setAttribute("src",
+ rewrite_relative_url("http://dilbert.com/",
+ $matches[0]));
+
+ $basenode = $entry;
+ break;
+ }
+ }
+
+ 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;
+ }
+}
+?>
diff --git a/plugins/af_comics/filters/af_comics_explosm.php b/plugins/af_comics/filters/af_comics_explosm.php
new file mode 100644
index 000000000..7e0621852
--- /dev/null
+++ b/plugins/af_comics/filters/af_comics_explosm.php
@@ -0,0 +1,49 @@
+<?php
+class Af_Comics_Explosm extends Af_ComicFilter {
+
+ function supported() {
+ return array("Cyanide and Happiness");
+ }
+
+ function process(&$article) {
+ $owner_uid = $article["owner_uid"];
+
+ if (strpos($article["link"], "explosm.net/comics") !== FALSE) {
+ if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
+
+ $doc = new DOMDocument();
+ @$doc->loadHTML(fetch_file_contents($article["link"]));
+
+ $basenode = false;
+
+ if ($doc) {
+ $xpath = new DOMXPath($doc);
+ $entries = $xpath->query('(//img[@src])'); // we might also check for img[@class='strip'] I guess...
+
+ $matches = array();
+
+ foreach ($entries as $entry) {
+
+ if (preg_match("/(http:\/\/.*\/db\/files\/Comics\/.*)/i", $entry->getAttribute("src"), $matches)) {
+
+ $basenode = $entry;
+ break;
+ }
+ }
+
+ 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;
+ }
+}
+?>
diff --git a/plugins/af_comics/filters/af_comics_gocomics.php b/plugins/af_comics/filters/af_comics_gocomics.php
new file mode 100644
index 000000000..bd57c08ff
--- /dev/null
+++ b/plugins/af_comics/filters/af_comics_gocomics.php
@@ -0,0 +1,62 @@
+<?php
+class Af_Comics_GoComics extends Af_ComicFilter {
+
+ function supported() {
+ return array("GoComics");
+ }
+
+ function process(&$article) {
+ $owner_uid = $article["owner_uid"];
+
+ if (strpos($article["guid"], "gocomics.com") !== FALSE) {
+ if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
+ $doc = new DOMDocument();
+ @$doc->loadHTML(fetch_file_contents($article["link"]));
+
+ $basenode = false;
+
+ if ($doc) {
+ $xpath = new DOMXPath($doc);
+ $entries = $xpath->query('(//img[@src])'); // we might also check for img[@class='strip'] I guess...
+
+ $matches = array();
+
+ foreach ($entries as $entry) {
+
+ if (preg_match("/(http:\/\/assets.amuniversal.com\/.*width.*)/i", $entry->getAttribute("src"), $matches)) {
+
+ $entry->setAttribute("src", $matches[0]);
+ $basenode = $entry;
+ break;
+ }
+ }
+
+ if (!$basenode) {
+ // fallback on the smaller version
+ foreach ($entries as $entry) {
+
+ if (preg_match("/(http:\/\/assets.amuniversal.com\/.*)/i", $entry->getAttribute("src"), $matches)) {
+
+ $entry->setAttribute("src", $matches[0]);
+ $basenode = $entry;
+ break;
+ }
+ }
+ }
+
+ 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;
+ }
+}
+?>
diff --git a/plugins/af_comics/filters/af_comics_pa.php b/plugins/af_comics/filters/af_comics_pa.php
new file mode 100644
index 000000000..b44de9cff
--- /dev/null
+++ b/plugins/af_comics/filters/af_comics_pa.php
@@ -0,0 +1,89 @@
+<?php
+class Af_Comics_Pa extends Af_ComicFilter {
+
+ function supported() {
+ return array("Penny Arcade");
+ }
+
+ function process(&$article) {
+ $owner_uid = $article["owner_uid"];
+
+ if (strpos($article["link"], "penny-arcade.com") !== FALSE && strpos($article["title"], "Comic:") !== FALSE) {
+ if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
+
+ if ($debug_enabled) {
+ _debug("af_pennyarcade: Processing comic");
+ }
+
+ $doc = new DOMDocument();
+ $doc->loadHTML(fetch_file_contents($article["link"]));
+
+ $basenode = false;
+
+ if ($doc) {
+ $xpath = new DOMXPath($doc);
+ $basenode = $xpath->query('(//div[@id="comicFrame"])')->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;
+ }
+
+ if (strpos($article["link"], "penny-arcade.com") !== FALSE && strpos($article["title"], "News Post:") !== FALSE) {
+ if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
+ if ($debug_enabled) {
+ _debug("af_pennyarcade: Processing news post");
+ }
+ $doc = new DOMDocument();
+ $doc->loadHTML(fetch_file_contents($article["link"]));
+
+ if ($doc) {
+ $xpath = new DOMXPath($doc);
+ $entries = $xpath->query('(//div[@class="post"])');
+
+ $basenode = false;
+
+ foreach ($entries as $entry) {
+ $basenode = $entry;
+ }
+
+ $meta = $xpath->query('(//div[@class="meta"])')->item(0);
+ if ($meta->parentNode) { $meta->parentNode->removeChild($meta); }
+
+ $header = $xpath->query('(//div[@class="postBody"]/h2)')->item(0);
+ if ($header->parentNode) { $header->parentNode->removeChild($header); }
+
+ $header = $xpath->query('(//div[@class="postBody"]/div[@class="comicPost"])')->item(0);
+ if ($header->parentNode) { $header->parentNode->removeChild($header); }
+
+ $avatar = $xpath->query('(//div[@class="avatar"]//img)')->item(0);
+ $basenode->insertBefore($avatar, $basenode->firstChild);
+
+ $uninteresting = $xpath->query('(//div[@class="avatar"])');
+ foreach ($uninteresting as $i) {
+ $i->parentNode->removeChild($i);
+ }
+
+ 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;
+ }
+}
+?>
diff --git a/plugins/af_comics/filters/af_comics_twp.php b/plugins/af_comics/filters/af_comics_twp.php
new file mode 100644
index 000000000..156b2b687
--- /dev/null
+++ b/plugins/af_comics/filters/af_comics_twp.php
@@ -0,0 +1,39 @@
+<?php
+class Af_Comics_Twp extends Af_ComicFilter {
+
+ function supported() {
+ return array("Three Word Phrase");
+ }
+
+ function process(&$article) {
+ $owner_uid = $article["owner_uid"];
+
+ if (strpos($article["link"], "threewordphrase.com") !== FALSE) {
+ if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
+
+ $doc = new DOMDocument();
+ @$doc->loadHTML(fetch_file_contents($article["link"]));
+
+ $basenode = false;
+
+ if ($doc) {
+ $xpath = new DOMXpath($doc);
+
+ $basenode = $xpath->query("//td/center/img")->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;
+ }
+}
+?>
diff --git a/plugins/af_comics/init.php b/plugins/af_comics/init.php
index 0d1a49a57..784be9e0a 100644
--- a/plugins/af_comics/init.php
+++ b/plugins/af_comics/init.php
@@ -2,6 +2,7 @@
class Af_Comics extends Plugin {
private $host;
+ private $filters = array();
function about() {
return array(1.0,
@@ -14,307 +15,62 @@ class Af_Comics extends Plugin {
$host->add_hook($host::HOOK_ARTICLE_FILTER, $this);
$host->add_hook($host::HOOK_PREFS_TAB, $this);
- }
-
- function hook_prefs_tab($args) {
- if ($args != "prefPrefs") return;
-
- print "<div dojoType=\"dijit.layout.AccordionPane\" title=\"".__('Feeds supported by af_comics')."\">";
-
- print_notice("This plugin supports the following comics:");
-
- print "<ul class=\"browseFeedList\" style=\"border-width : 1px\">";
- print "<li>Buni</li>
- <li>Buttersafe</li>
- <li>CSection</li>
- <li>Ctrl+Alt+Del</li>
- <li>Dilbert</li>
- <li>Explosm</li>
- <li>GoComics</li>
- <li>Happy Jar</li>
- <li>Penny Arcade</li>
- <li>Three word phrase</li>
- <li>Whomp</li>";
- print "</ul>";
-
- print "</div>";
- }
-
- function hook_article_filter($article) {
- $owner_uid = $article["owner_uid"];
-
- $found = false;
-
- # div#comic - comicpress?
-
- 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"];
- }
- }
-
- if (strpos($article["guid"], "dilbert.com") !== FALSE) {
- if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
- $doc = new DOMDocument();
- @$doc->loadHTML(fetch_file_contents($article["link"]));
-
- $basenode = false;
-
- if ($doc) {
- $xpath = new DOMXPath($doc);
- $entries = $xpath->query('(//img[@src])'); // we might also check for img[@class='strip'] I guess...
-
- $matches = array();
-
- foreach ($entries as $entry) {
-
- if (preg_match("/dyn\/str_strip\/.*zoom\.gif$/", $entry->getAttribute("src"), $matches)) {
-
- $entry->setAttribute("src",
- rewrite_relative_url("http://dilbert.com/",
- $matches[0]));
-
- $basenode = $entry;
- break;
- }
- }
-
- 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"];
- }
- }
-
- if (strpos($article["link"], "explosm.net/comics") !== FALSE) {
- if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
-
- $doc = new DOMDocument();
- @$doc->loadHTML(fetch_file_contents($article["link"]));
-
- $basenode = false;
-
- if ($doc) {
- $xpath = new DOMXPath($doc);
- $entries = $xpath->query('(//img[@src])'); // we might also check for img[@class='strip'] I guess...
- $matches = array();
+ require_once __DIR__ . "/filter_base.php";
- foreach ($entries as $entry) {
+ $filters = glob(__DIR__ . "/filters/*.php");
- if (preg_match("/(http:\/\/.*\/db\/files\/Comics\/.*)/i", $entry->getAttribute("src"), $matches)) {
+ foreach ($filters as $file) {
+ require_once $file;
+ $filter_name = preg_replace("/\..*$/", "", basename($file));
- $basenode = $entry;
- break;
- }
- }
+ $filter = new $filter_name();
- 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"];
+ if (is_subclass_of($filter, "Af_ComicFilter")) {
+ array_push($this->filters, $filter);
}
}
- if (strpos($article["link"], "cad-comic.com/cad/") !== FALSE) {
- if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
-
- $doc = new DOMDocument();
- @$doc->loadHTML(fetch_file_contents($article["link"]));
-
- $basenode = false;
-
- if ($doc) {
- $xpath = new DOMXPath($doc);
- $basenode = $xpath->query('(//img[contains(@src, "/comics/cad-")])')->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"];
- }
- }
-
- if (strpos($article["guid"], "gocomics.com") !== FALSE) {
- if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
- $doc = new DOMDocument();
- @$doc->loadHTML(fetch_file_contents($article["link"]));
-
- $basenode = false;
-
- if ($doc) {
- $xpath = new DOMXPath($doc);
- $entries = $xpath->query('(//img[@src])'); // we might also check for img[@class='strip'] I guess...
-
- $matches = array();
-
- foreach ($entries as $entry) {
-
- if (preg_match("/(http:\/\/assets.amuniversal.com\/.*width.*)/i", $entry->getAttribute("src"), $matches)) {
-
- $entry->setAttribute("src", $matches[0]);
- $basenode = $entry;
- break;
- }
- }
-
- if (!$basenode) {
- // fallback on the smaller version
- foreach ($entries as $entry) {
-
- if (preg_match("/(http:\/\/assets.amuniversal.com\/.*)/i", $entry->getAttribute("src"), $matches)) {
-
- $entry->setAttribute("src", $matches[0]);
- $basenode = $entry;
- break;
- }
- }
- }
-
- 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"];
- }
- }
+ }
- if (strpos($article["link"], "penny-arcade.com") !== FALSE && strpos($article["title"], "Comic:") !== FALSE) {
- if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
+ function hook_prefs_tab($args) {
+ if ($args != "prefPrefs") return;
- if ($debug_enabled) {
- _debug("af_pennyarcade: Processing comic");
- }
+ print "<div dojoType=\"dijit.layout.AccordionPane\" title=\"".__('Feeds supported by af_comics')."\">";
- $doc = new DOMDocument();
- $doc->loadHTML(fetch_file_contents($article["link"]));
+ print_notice("This plugin can be easily extended by adding filters to <code>plugins/af_comics/filters</code>.");
- $basenode = false;
+ print "<p>" . __("The following comics are currently supported:") . "</p>";
- if ($doc) {
- $xpath = new DOMXPath($doc);
- $basenode = $xpath->query('(//div[@id="comicFrame"])')->item(0);
+ $comics = array();
- 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"];
+ foreach ($this->filters as $f) {
+ foreach ($f->supported() as $comic) {
+ array_push($comics, $comic);
}
}
- if (strpos($article["link"], "penny-arcade.com") !== FALSE && strpos($article["title"], "News Post:") !== FALSE) {
- if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
- if ($debug_enabled) {
- _debug("af_pennyarcade: Processing news post");
- }
- $doc = new DOMDocument();
- $doc->loadHTML(fetch_file_contents($article["link"]));
-
- if ($doc) {
- $xpath = new DOMXPath($doc);
- $entries = $xpath->query('(//div[@class="post"])');
-
- $basenode = false;
-
- foreach ($entries as $entry) {
- $basenode = $entry;
- }
-
- $meta = $xpath->query('(//div[@class="meta"])')->item(0);
- if ($meta->parentNode) { $meta->parentNode->removeChild($meta); }
+ asort($comics);
- $header = $xpath->query('(//div[@class="postBody"]/h2)')->item(0);
- if ($header->parentNode) { $header->parentNode->removeChild($header); }
-
- $header = $xpath->query('(//div[@class="postBody"]/div[@class="comicPost"])')->item(0);
- if ($header->parentNode) { $header->parentNode->removeChild($header); }
-
- $avatar = $xpath->query('(//div[@class="avatar"]//img)')->item(0);
- $basenode->insertBefore($avatar, $basenode->firstChild);
-
- $uninteresting = $xpath->query('(//div[@class="avatar"])');
- foreach ($uninteresting as $i) {
- $i->parentNode->removeChild($i);
- }
-
- 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"];
- }
+ print "<ul class=\"browseFeedList\" style=\"border-width : 1px\">";
+ foreach ($comics as $comic) {
+ print "<li>$comic</li>";
}
+ print "</ul>";
- if (strpos($article["link"], "threewordphrase.com") !== FALSE) {
- if (strpos($article["plugin_data"], "af_comics,$owner_uid:") === FALSE) {
-
- $doc = new DOMDocument();
- @$doc->loadHTML(fetch_file_contents($article["link"]));
-
- $basenode = false;
-
- if ($doc) {
- $xpath = new DOMXpath($doc);
+ print "</div>";
+ }
- $basenode = $xpath->query("//td/center/img")->item(0);
+ function hook_article_filter($article) {
+ $owner_uid = $article["owner_uid"];
- 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"];
- }
+ foreach ($this->filters as $f) {
+ if ($f->process($article))
+ break;
}
return $article;
+
}
function api_version() {