From: Andrew Dolgov Date: Sun, 29 Jan 2017 11:36:37 +0000 (+0300) Subject: af_redditimgur: inline streamable.com videos X-Git-Tag: 17.4~64 X-Git-Url: https://git.wh0rd.org/?a=commitdiff_plain;h=60e97d9e63df7cdbf6fc9ece09ae4bb79e4a5272;p=tt-rss.git af_redditimgur: inline streamable.com videos --- diff --git a/plugins/af_redditimgur/init.php b/plugins/af_redditimgur/init.php index 7ab07b90..29ea329a 100755 --- a/plugins/af_redditimgur/init.php +++ b/plugins/af_redditimgur/init.php @@ -152,6 +152,32 @@ class Af_RedditImgur extends Plugin { } } + if (!$found && preg_match("/https?:\/\/(www\.)?streamable.com\//i", $entry->getAttribute("href"))) { + + _debug("Handling as Streamable", $debug); + + $tmp = fetch_file_contents($entry->getAttribute("href")); + + if ($tmp) { + $tmpdoc = new DOMDocument(); + + if (@$tmpdoc->loadHTML($tmp)) { + $tmpxpath = new DOMXPath($tmpdoc); + + $source_node = $tmpxpath->query("//video[contains(@class,'video-player-tag')]//source[contains(@src, '.mp4')]")->item(0); + $poster_node = $tmpxpath->query("//video[contains(@class,'video-player-tag') and @poster]")->item(0); + + if ($source_node && $poster_node) { + $source_stream = $source_node->getAttribute("src"); + $poster_url = $poster_node->getAttribute("poster"); + + $this->handle_as_video($doc, $entry, $source_stream, $poster_url); + $found = 1; + } + } + } + } + // imgur .gif -> .gifv if (!$found && preg_match("/i\.imgur\.com\/(.*?)\.gif$/i", $entry->getAttribute("href"))) { _debug("Handling as imgur gif (->gifv)", $debug);