X-Git-Url: https://git.mxchange.org/?a=blobdiff_plain;f=mod%2Fupdate_profile.php;h=f293088a962c1896a10e26cf5844408fbf0d37d0;hb=de4a2e6fd03cd0aab94a256eba92ed593931534b;hp=8ea86eb91ecc7719b4651238f831fdcd3213369b;hpb=9f81c3345b40d635a34f0448dd625b17f20508c3;p=friendica.git
diff --git a/mod/update_profile.php b/mod/update_profile.php
index 8ea86eb91e..f293088a96 100644
--- a/mod/update_profile.php
+++ b/mod/update_profile.php
@@ -1,16 +1,54 @@
\r\n";
- echo (($_GET['msie'] == 1) ? '' : '');
- echo str_replace("\t",' ',profile_content($a,true));
- echo (($_GET['msie'] == 1) ? '
' : '');
+
+ // We can remove this hack once Internet Explorer recognises HTML5 natively
+ echo "";
+
+ /**
+ * Grab the page inner contents by calling the content function from the profile module directly,
+ * but move any image src attributes to another attribute name. This is because
+ * some browsers will prefetch all the images for the page even if we don't need them.
+ * The only ones we need to fetch are those for new page additions, which we'll discover
+ * on the client side and then swap the image back.
+ */
+
+ $text = profile_content($a, $profile_uid);
+
+ $pattern = "/
]*) src=\"([^\"]*)\"/";
+ $replace = "
".t("[Embedded content - reload page to view]")."
";
+ $pattern = "/<\s*audio[^>]*>(.*?)<\s*\/\s*audio>/i";
+ $text = preg_replace($pattern, $replace, $text);
+ $pattern = "/<\s*video[^>]*>(.*?)<\s*\/\s*video>/i";
+ $text = preg_replace($pattern, $replace, $text);
+ $pattern = "/<\s*embed[^>]*>(.*?)<\s*\/\s*embed>/i";
+ $text = preg_replace($pattern, $replace, $text);
+ $pattern = "/<\s*iframe[^>]*>(.*?)<\s*\/\s*iframe>/i";
+ $text = preg_replace($pattern, $replace, $text);
+ }
+
+ // reportedly some versions of MSIE don't handle tabs in XMLHttpRequest documents very well
+ echo str_replace("\t", " ", $text);
+ echo "";
echo "\r\n";
killme();
-
}
\ No newline at end of file