diff options
author | JoshyPHP <s9e.dev@gmail.com> | 2017-04-07 08:49:56 +0200 |
---|---|---|
committer | Tristan Darricau <github@nicofuma.fr> | 2017-04-18 23:33:35 +0200 |
commit | ddcd0f243791ea64373b53f077689df0c46c713a (patch) | |
tree | 363baf97112521a4c1779281282dece0f6001edc /phpBB/phpbb/textformatter | |
parent | d4f0c79b565f558180225027039ec6494131f85e (diff) | |
download | forums-ddcd0f243791ea64373b53f077689df0c46c713a.tar forums-ddcd0f243791ea64373b53f077689df0c46c713a.tar.gz forums-ddcd0f243791ea64373b53f077689df0c46c713a.tar.bz2 forums-ddcd0f243791ea64373b53f077689df0c46c713a.tar.xz forums-ddcd0f243791ea64373b53f077689df0c46c713a.zip |
[ticket/15163] Escape curly braces in smilies HTML attributes
PHPBB3-15163
Diffstat (limited to 'phpBB/phpbb/textformatter')
-rw-r--r-- | phpBB/phpbb/textformatter/s9e/factory.php | 16 |
1 files changed, 15 insertions, 1 deletions
diff --git a/phpBB/phpbb/textformatter/s9e/factory.php b/phpBB/phpbb/textformatter/s9e/factory.php index 5cbf2712f7..7719ce5afa 100644 --- a/phpBB/phpbb/textformatter/s9e/factory.php +++ b/phpBB/phpbb/textformatter/s9e/factory.php @@ -311,7 +311,7 @@ class factory implements \phpbb\textformatter\cache_interface { $configurator->Emoticons->set( $row['code'], - '<img class="smilies" src="{$T_SMILIES_PATH}/' . htmlspecialchars($row['smiley_url']) . '" width="' . $row['smiley_width'] . '" height="' . $row['smiley_height'] . '" alt="{.}" title="' . htmlspecialchars($row['emotion']) . '"/>' + '<img class="smilies" src="{$T_SMILIES_PATH}/' . $this->escape_html_attribute($row['smiley_url']) . '" width="' . $row['smiley_width'] . '" height="' . $row['smiley_height'] . '" alt="{.}" title="' . $this->escape_html_attribute($row['emotion']) . '"/>' ); } @@ -442,6 +442,20 @@ class factory implements \phpbb\textformatter\cache_interface } /** + * Escape a literal to be used in an HTML attribute in an XSL template + * + * Escapes "HTML special chars" for obvious reasons and curly braces to avoid them + * being interpreted as an attribute value template + * + * @param string $value Original string + * @return string Escaped string + */ + protected function escape_html_attribute($value) + { + return htmlspecialchars(strtr($value, ['{' => '{{', '}' => '}}']), ENT_COMPAT | ENT_XML1, 'UTF-8'); + } + + /** * Return the default BBCodes configuration * * @return array 2D array. Each element has a 'usage' key, a 'template' key, and an optional 'options' key |