diff options
author | Andrew Dolgov <[email protected]> | 2015-05-14 13:00:06 +0300 |
---|---|---|
committer | Andrew Dolgov <[email protected]> | 2015-05-14 13:00:06 +0300 |
commit | 89722f508e11d758daafb5a6be8c99edaf39ba27 (patch) | |
tree | d9d7d437558a06732bc3aeb96e9bf444d0ac70ed | |
parent | 6da5c4c3659485328ed99b628800f8185996d13e (diff) | |
parent | 248c5a6ab1a3817d32b205c4a8a3351f8e9574d9 (diff) |
Merge pull request #453 from aliz27/patch-1
Patch 1
-rw-r--r-- | plugins/af_redditimgur/init.php | 54 |
1 files changed, 52 insertions, 2 deletions
diff --git a/plugins/af_redditimgur/init.php b/plugins/af_redditimgur/init.php index a23b3527f..1bf91e88a 100644 --- a/plugins/af_redditimgur/init.php +++ b/plugins/af_redditimgur/init.php @@ -28,7 +28,57 @@ class Af_RedditImgur extends Plugin { foreach ($entries as $entry) { if ($entry->hasAttribute("href")) { - if (preg_match("/\.(jpg|jpeg|gif|png)$/i", $entry->getAttribute("href"))) { + + if (preg_match("/\.(gifv)$/i", $entry->getAttribute("href"))) { + + $gifv_meta = fetch_file_contents($entry->getAttribute("href"), + false, false, false, false, 10); + + if ($gifv_meta) { + $adoc = new DOMDocument(); + @$adoc->loadHTML($gifv_meta); + + if ($adoc) { + $axpath = new DOMXPath($adoc); + $aentries = $axpath->query('(//meta)'); + + $width = false; + $height = false; + + foreach ($aentries as $aentry) { + if (strpos($aentry->getAttribute("property"), "og:image:width") !== FALSE) { + $width = $aentry->getAttribute("content"); + } + if (strpos($aentry->getAttribute("property"), "og:image:height") !== FALSE) { + $height = $aentry->getAttribute("content"); + } + } + } + } + + if ($width && $height) { + + $iframe = $doc->createElement('iframe'); + $iframe->setAttribute("src", str_replace("http:", "", $entry->getAttribute("href"))); + $iframe->setAttribute("frameborder", "0"); + $iframe->setAttribute("width", $width); + $iframe->setAttribute("height", $height); + + $br = $doc->createElement('br'); + $entry->parentNode->insertBefore($iframe, $entry); + $entry->parentNode->insertBefore($br, $entry); + + // add empty img tag to disable display of attachment + $img = $doc->createElement('img'); + $img->setAttribute("src", "data:image/gif;base64,R0lGODlhAQABAAD/ACwAAAAAAQABAAACADs%3D"); + $img->setAttribute("width", "0"); + $img->setAttribute("height", "0"); + $entry->parentNode->insertBefore($img, $entry); + $found = true; + } + } + + if (preg_match("/\.(jpg|jpeg|gif|png)(\?[0-9])?$/i", $entry->getAttribute("href"))) { $img = $doc->createElement('img'); $img->setAttribute("src", $entry->getAttribute("href")); @@ -42,7 +92,7 @@ class Af_RedditImgur extends Plugin { // links to imgur pages $matches = array(); - if (preg_match("/^https?:\/\/imgur.com\/([^\.\/]+$)/", $entry->getAttribute("href"), $matches)) { + if (preg_match("/^https?:\/\/(m\.)?imgur.com\/([^\.\/]+$)/", $entry->getAttribute("href"), $matches)) { $token = $matches[1]; |