summaryrefslogtreecommitdiff
path: root/plugins/af_elreg/init.php
diff options
context:
space:
mode:
authorYoungMin Park <[email protected]>2014-11-04 11:49:43 +0900
committerYoungMin Park <[email protected]>2014-11-04 11:49:43 +0900
commita5bbb2bec133bdee08b361628f32430ae3884107 (patch)
treeb203105149ec234ebe155d5718d2cbb6390b4a45 /plugins/af_elreg/init.php
parent12727ad17d125eb2f3f243231ccca1cb0a5a7b4b (diff)
parent2f43089de1ead3f164b8b31967d1abbb784319fa (diff)
Merge pull request #1 from gothfox/master
Update from original
Diffstat (limited to 'plugins/af_elreg/init.php')
-rw-r--r--plugins/af_elreg/init.php50
1 files changed, 50 insertions, 0 deletions
diff --git a/plugins/af_elreg/init.php b/plugins/af_elreg/init.php
new file mode 100644
index 000000000..c8d5516ee
--- /dev/null
+++ b/plugins/af_elreg/init.php
@@ -0,0 +1,50 @@
+<?php
+class Af_ElReg extends Plugin {
+
+ private $host;
+
+ function about() {
+ return array(1.0,
+ "Fetch content of The Register feeds",
+ "fox");
+ }
+
+ function init($host) {
+ $this->host = $host;
+
+ $host->add_hook($host::HOOK_ARTICLE_FILTER, $this);
+ }
+
+ function hook_article_filter($article) {
+ if (strpos($article["link"], "theregister.co.uk") !== FALSE) {
+
+ $doc = new DOMDocument();
+ @$doc->loadHTML(fetch_file_contents($article["link"]));
+
+ $basenode = false;
+
+ if ($doc) {
+ $xpath = new DOMXPath($doc);
+
+ $trash = $xpath->query("//*[@class='wptl top' or @class='wptl btm']");
+
+ foreach ($trash as $t) {
+ $t->parentNode->removeChild($t);
+ }
+
+ $basenode = $doc->getElementById("body");
+
+ if ($basenode) {
+ $article["content"] = $doc->saveXML($basenode);
+ }
+ }
+ }
+
+ return $article;
+ }
+
+ function api_version() {
+ return 2;
+ }
+}
+?>