From: Hypolite Petovan Date: Sat, 18 May 2019 17:15:01 +0000 (-0400) Subject: Replace htmlspecialchars_decode with html_entity_decode in XML::unescape X-Git-Url: https://git.mxchange.org/?a=commitdiff_plain;h=8fb9722cdc24ed9c6b12322e1b964963625e0c1f;p=friendica.git Replace htmlspecialchars_decode with html_entity_decode in XML::unescape - Replace htmlspecialchars with htmlentities in XML::escape - This allows for converting all entities from Diaspora messages to regular characters --- diff --git a/src/Util/XML.php b/src/Util/XML.php index 4dd6d84ecb..3159fb95e9 100644 --- a/src/Util/XML.php +++ b/src/Util/XML.php @@ -4,8 +4,8 @@ */ namespace Friendica\Util; -use Friendica\Core\Logger; use DOMXPath; +use Friendica\Core\Logger; use Friendica\Core\System; use SimpleXMLElement; @@ -465,12 +465,13 @@ class XML /** * escape text ($str) for XML transport + * * @param string $str * @return string Escaped text. */ public static function escape($str) { - $buffer = htmlspecialchars($str, ENT_QUOTES, "UTF-8"); + $buffer = htmlentities($str, ENT_QUOTES, 'UTF-8'); $buffer = trim($buffer); return $buffer; @@ -478,27 +479,30 @@ class XML /** * undo an escape + * * @param string $s xml escaped text * @return string unescaped text */ public static function unescape($s) { - $ret = htmlspecialchars_decode($s, ENT_QUOTES); + $ret = html_entity_decode($s, ENT_QUOTES); return $ret; } /** * apply escape() to all values of array $val, recursively + * * @param array $val - * @return array + * @return array|string */ public static function arrayEscape($val) { if (is_bool($val)) { - return $val?"true":"false"; + return $val ? 'true' : 'false'; } elseif (is_array($val)) { return array_map('XML::arrayEscape', $val); } + return self::escape((string) $val); } }