From: Andrew Dolgov Date: Tue, 12 Mar 2013 07:26:44 +0000 (+0400) Subject: af_redditimgur: support albums X-Git-Tag: 1.7.3~15 X-Git-Url: https://git.wh0rd.org/?a=commitdiff_plain;h=35055d050b51693e2f85dcd4e6ce3ce60268d00b;p=tt-rss.git af_redditimgur: support albums --- diff --git a/plugins/af_redditimgur/init.php b/plugins/af_redditimgur/init.php index 53cb875c..5e863108 100644 --- a/plugins/af_redditimgur/init.php +++ b/plugins/af_redditimgur/init.php @@ -45,7 +45,7 @@ class Af_RedditImgur extends Plugin { // links to imgur pages $matches = array(); - if (preg_match("/^http:\/\/imgur.com\/([^\.]+$)/", $entry->getAttribute("href"), $matches)) { + if (preg_match("/^http:\/\/imgur.com\/([^\.\/]+$)/", $entry->getAttribute("href"), $matches)) { $token = $matches[1]; @@ -66,11 +66,37 @@ class Af_RedditImgur extends Plugin { $img->setAttribute("src", $aentry->getAttribute("src")); $entry->parentNode->insertBefore($img, $entry); $found = true; + + break; } } } } } + + // linked albums, ffs + if (preg_match("/^http:\/\/imgur.com\/a\/[^\.]+$/", $entry->getAttribute("href"), $matches)) { + + $album_content = fetch_file_contents($entry->getAttribute("href"), + false, false, false, false, 10); + + if ($album_content) { + $adoc = new DOMDocument(); + @$adoc->loadHTML($album_content); + + if ($adoc) { + $axpath = new DOMXPath($adoc); + $aentries = $axpath->query("//div[@class='image']//a[@href and @class='zoom']"); + + foreach ($aentries as $aentry) { + $img = $doc->createElement('img'); + $img->setAttribute("src", $aentry->getAttribute("href")); + $entry->parentNode->insertBefore($img, $entry); + $found = true; + } + } + } + } } // remove tiny thumbnails