]> git.wh0rd.org - tt-rss.git/blame - plugins/af_buttersafe/init.php
remove $link
[tt-rss.git] / plugins / af_buttersafe / init.php
CommitLineData
1610cdce
AD
1<?php
2class Af_Buttersafe extends Plugin {
3
1610cdce
AD
4 private $host;
5
6 function about() {
7 return array(1.0,
8 "Strip unnecessary stuff from Buttersafe feeds",
9 "fox");
10 }
11
12 function init($host) {
1610cdce
AD
13 $this->host = $host;
14
15 $host->add_hook($host::HOOK_ARTICLE_FILTER, $this);
16 }
17
18 function hook_article_filter($article) {
19 $owner_uid = $article["owner_uid"];
20
e02555c1
AD
21 if (strpos($article["guid"], "buttersafe.com") !== FALSE) {
22 if (strpos($article["plugin_data"], "buttersafe,$owner_uid:") === FALSE) {
1610cdce 23
e02555c1
AD
24 $doc = new DOMDocument();
25 @$doc->loadHTML(fetch_file_contents($article["link"]));
1610cdce 26
e02555c1 27 $basenode = false;
1610cdce 28
e02555c1
AD
29 if ($doc) {
30 $xpath = new DOMXPath($doc);
31 $entries = $xpath->query('(//img[@src])');
1610cdce 32
e02555c1 33 $matches = array();
1610cdce 34
e02555c1 35 foreach ($entries as $entry) {
1610cdce 36
e02555c1 37 if (preg_match("/(http:\/\/buttersafe.com\/comics\/\d{4}.*)/i", $entry->getAttribute("src"), $matches)) {
1610cdce 38
e02555c1
AD
39 $basenode = $entry;
40 break;
41 }
1610cdce 42 }
1610cdce 43
e02555c1 44 if ($basenode) {
cc38c8e5 45 $article["content"] = $doc->saveXML($basenode);
e02555c1
AD
46 $article["plugin_data"] = "buttersafe,$owner_uid:" . $article["plugin_data"];
47 }
1610cdce 48 }
e02555c1
AD
49 } else if (isset($article["stored"]["content"])) {
50 $article["content"] = $article["stored"]["content"];
1610cdce 51 }
1610cdce
AD
52 }
53
54 return $article;
55 }
56}
57?>