summaryrefslogtreecommitdiff
path: root/plugins/af_tumblr_1280
diff options
context:
space:
mode:
authorAndrew Dolgov <[email protected]>2014-11-15 16:37:21 +0300
committerAndrew Dolgov <[email protected]>2014-11-15 16:37:21 +0300
commit84c6f17deb6d35f3d1ef4738488b20f4ae4bcf34 (patch)
tree2f0a821b195a471de971f69c6074712b5cd128d9 /plugins/af_tumblr_1280
parent346297d4d216e58566e6f35b7b6fbd2235f46258 (diff)
add af_tumblr_1280
Diffstat (limited to 'plugins/af_tumblr_1280')
-rw-r--r--plugins/af_tumblr_1280/init.php79
1 files changed, 79 insertions, 0 deletions
diff --git a/plugins/af_tumblr_1280/init.php b/plugins/af_tumblr_1280/init.php
new file mode 100644
index 000000000..f9938048b
--- /dev/null
+++ b/plugins/af_tumblr_1280/init.php
@@ -0,0 +1,79 @@
+<?php
+class Af_Tumblr_1280 extends Plugin {
+ private $host;
+
+ function about() {
+ return array(1.0,
+ "Replace Tumblr pictures with largest size if available",
+ "fox");
+ }
+
+ function init($host) {
+ $this->host = $host;
+
+ if (function_exists("curl_init")) {
+ $host->add_hook($host::HOOK_ARTICLE_FILTER, $this);
+ }
+ }
+
+ function hook_article_filter($article) {
+
+ $owner_uid = $article["owner_uid"];
+
+ $charset_hack = '<head>
+ <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/>
+ </head>';
+
+ $doc = new DOMDocument();
+ $doc->loadHTML($charset_hack . $article["content"]);
+
+ $found = false;
+
+ if ($doc) {
+ $xpath = new DOMXpath($doc);
+
+ $images = $xpath->query('(//img[contains(@src, \'media.tumblr.com\')])');
+
+ foreach ($images as $img) {
+ $src = $img->getAttribute("src");
+
+ $test_src = preg_replace("/_\d{3}.(jpg|gif|png)/", "_1280.$1", $src);
+
+ if ($src != $test_src) {
+
+ $ch = curl_init($test_src);
+ curl_setopt($ch, CURLOPT_TIMEOUT, 5);
+ curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
+ curl_setopt($ch, CURLOPT_HEADER, true);
+ curl_setopt($ch, CURLOPT_NOBODY, true);
+ curl_setopt($ch, CURLOPT_FOLLOWLOCATION,
+ !ini_get("safe_mode") && !ini_get("open_basedir"));
+ curl_setopt($ch, CURLOPT_USERAGENT, SELF_USER_AGENT);
+
+ @$result = curl_exec($ch);
+ $http_code = curl_getinfo($ch, CURLINFO_HTTP_CODE);
+
+ if ($result && $http_code == 200) {
+ $img->setAttribute("src", $test_src);
+ $found = true;
+ }
+ }
+ }
+
+ if ($found) {
+ $doc->removeChild($doc->firstChild); //remove doctype
+ $article["content"] = $doc->saveHTML();
+ }
+ }
+
+ return $article;
+
+ }
+
+
+ function api_version() {
+ return 2;
+ }
+
+}
+?>