1
0
Fork 0
mirror of https://we.phorge.it/source/phorge.git synced 2025-01-10 23:01:04 +01:00

Disallow <! in <script>

Summary:
HTML5 has this crazy script escaping states:

- Script data escaped dash dash state
- Script data double escaped state

https://communities.coverity.com/blogs/security/2012/11/16/did-i-do-that-html-5-js-escapers-3

Perhaps `<!` is too aggressive but I didn't spend much time searching for a more fine grained expression.

Test Plan: Searched for `renderInlineScript()`.

Reviewers: epriestley

Reviewed By: epriestley

CC: Korvin, epriestley, aran

Differential Revision: https://secure.phabricator.com/D7329
This commit is contained in:
Jakub Vrana 2013-10-16 09:28:37 -07:00
parent d34143c723
commit 29391a658e
3 changed files with 6 additions and 0 deletions

View file

@ -51,6 +51,7 @@ final class DifferentialRevisionViewController extends DifferentialController {
$diff_vs = $request->getInt('vs');
$target_id = $request->getInt('id');
phlog($target_id);
$target = idx($diffs, $target_id, end($diffs));
$target_manual = $target;

View file

@ -89,6 +89,8 @@ final class DifferentialRevisionUpdateHistoryView extends AphrontView {
$new = null;
}
phlog($this->selectedVersusDiffID, $this->selectedDiffID);
if ($max_id != $id) {
$uniq = celerity_generate_unique_node_id();
$old_checked = ($this->selectedVersusDiffID == $id);

View file

@ -193,6 +193,9 @@ final class CelerityStaticResourceResponse {
throw new Exception(
'Literal </script> is not allowed inside inline script.');
}
if (strpos($data, '<!') !== false) {
throw new Exception('Literal <! is not allowed inside inline script.');
}
return hsprintf(
// We don't use <![CDATA[ ]]> because it is ignored by HTML parsers. We
// would need to send the document with XHTML content type.