Skip to content

Commit

Permalink
Fix two exponential regex backtracking vulnerabilities
Browse files Browse the repository at this point in the history
ESCAPED_CHAR already matches `\\`, so matching it again in another
alternative was just causing exponential complexity explosion.

Fixes commonmark#157.

Signed-off-by: Anders Kaseorg <[email protected]>
  • Loading branch information
andersk committed Mar 10, 2019
1 parent 2052768 commit 45e49ae
Showing 1 changed file with 3 additions and 7 deletions.
10 changes: 3 additions & 7 deletions lib/inlines.js
Original file line number Diff line number Diff line change
Expand Up @@ -45,8 +45,7 @@ var reLinkTitle = new RegExp(
'|' +
'\\((' + ESCAPED_CHAR + '|[^)\\x00])*\\))');

var reLinkDestinationBraces = new RegExp(
'^(?:[<](?:[^<>\\n\\\\\\x00]' + '|' + ESCAPED_CHAR + '|' + '\\\\)*[>])');
var reLinkDestinationBraces = /^(?:<(?:[^<>\n\\\x00]|\\.)*\\?>)/;

var reEscapable = new RegExp('^' + ESCAPABLE);

Expand Down Expand Up @@ -78,8 +77,7 @@ var reInitialSpace = /^ */;

var reSpaceAtEndOfLine = /^ *(?:\n|$)/;

var reLinkLabel = new RegExp('^\\[(?:[^\\\\\\[\\]]|' + ESCAPED_CHAR +
'|\\\\){0,1000}\\]');
var reLinkLabel = /^\[(?:[^\\\[\]]|\\.){0,1000}\]/;

// Matches a string of non-special characters.
var reMain = /^[^\n`\[\]\\!<&*_'"]+/m;
Expand Down Expand Up @@ -524,9 +522,7 @@ var parseLinkDestination = function() {
// Attempt to parse a link label, returning number of characters parsed.
var parseLinkLabel = function() {
var m = this.match(reLinkLabel);
// Note: our regex will allow something of form [..\];
// we disallow it here rather than using lookahead in the regex:
if (m === null || m.length > 1001 || /[^\\]\\\]$/.exec(m)) {
if (m === null || m.length > 1001) {
return 0;
} else {
return m.length;
Expand Down

0 comments on commit 45e49ae

Please sign in to comment.