diff options
author | Andrew Dolgov <[email protected]> | 2013-02-23 12:07:46 +0400 |
---|---|---|
committer | Andrew Dolgov <[email protected]> | 2013-02-23 12:07:46 +0400 |
commit | e02555c1b8efad4fdc918e8245624e0b641ac6df (patch) | |
tree | fc30ca23ff7b1b82359cd7bb03b3a1fc808ceac4 /plugins/af_gocomics/init.php | |
parent | 389859b5d459f3b6ce3c09755b2d15069a77334a (diff) |
add af_* plugin workaround for already processed article
Diffstat (limited to 'plugins/af_gocomics/init.php')
-rw-r--r-- | plugins/af_gocomics/init.php | 39 |
1 files changed, 21 insertions, 18 deletions
diff --git a/plugins/af_gocomics/init.php b/plugins/af_gocomics/init.php index 829dda999..da5242595 100644 --- a/plugins/af_gocomics/init.php +++ b/plugins/af_gocomics/init.php @@ -20,34 +20,37 @@ class Af_GoComics extends Plugin { function hook_article_filter($article) { $owner_uid = $article["owner_uid"]; - if (strpos($article["guid"], "gocomics.com") !== FALSE && strpos($article["plugin_data"], "gocomics,$owner_uid:") === FALSE) { - $doc = new DOMDocument(); - @$doc->loadHTML(fetch_file_contents($article["link"])); + if (strpos($article["guid"], "gocomics.com") !== FALSE) { + if (strpos($article["plugin_data"], "gocomics,$owner_uid:") === FALSE) { + $doc = new DOMDocument(); + @$doc->loadHTML(fetch_file_contents($article["link"])); - $basenode = false; + $basenode = false; - if ($doc) { - $xpath = new DOMXPath($doc); - $entries = $xpath->query('(//img[@src])'); // we might also check for img[@class='strip'] I guess... + if ($doc) { + $xpath = new DOMXPath($doc); + $entries = $xpath->query('(//img[@src])'); // we might also check for img[@class='strip'] I guess... - $matches = array(); + $matches = array(); - foreach ($entries as $entry) { + foreach ($entries as $entry) { - if (preg_match("/(http:\/\/assets.amuniversal.com\/.*)/i", $entry->getAttribute("src"), $matches)) { + if (preg_match("/(http:\/\/assets.amuniversal.com\/.*)/i", $entry->getAttribute("src"), $matches)) { - $entry->setAttribute("src", $matches[0]); - $basenode = $entry; - break; + $entry->setAttribute("src", $matches[0]); + $basenode = $entry; + break; + } } - } - if ($basenode) { - $article["content"] = $doc->saveXML($basenode, LIBXML_NOEMPTYTAG); + if ($basenode) { + $article["content"] = $doc->saveXML($basenode, LIBXML_NOEMPTYTAG); + $article["plugin_data"] = "gocomics,$owner_uid:" . $article["plugin_data"]; + } } + } else if (isset($article["stored"]["content"])) { + $article["content"] = $article["stored"]["content"]; } - - $article["plugin_data"] = "gocomics,$owner_uid:" . $article["plugin_data"]; } return $article; |