summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2015-05-14 13:00:06 +0300
committerAndrew Dolgov <[email protected]>2015-05-14 13:00:06 +0300
commit89722f508e11d758daafb5a6be8c99edaf39ba27 (patch)
treed9d7d437558a06732bc3aeb96e9bf444d0ac70ed
parent6da5c4c3659485328ed99b628800f8185996d13e (diff)
parent248c5a6ab1a3817d32b205c4a8a3351f8e9574d9 (diff)
Merge pull request #453 from aliz27/patch-1
Patch 1
-rw-r--r--plugins/af_redditimgur/init.php54
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", "%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];