Prevent ReDoS by not using a regexp to verify floating point numbers
authorRichard van Velzen <rvanvelzen@experty.com>
Mon, 9 Nov 2015 10:28:27 +0000 (11:28 +0100)
committerRichard van Velzen <rvanvelzen@experty.com>
Mon, 9 Nov 2015 10:28:27 +0000 (11:28 +0100)
`parseFloat` will return `NaN` for invalid numbers anyway, which is the check used to throw the parse error.

Fixes #857

lib/parse.js

index 1ab0358..4c548a2 100644 (file)
@@ -59,7 +59,6 @@ var OPERATOR_CHARS = makePredicate(characters("+-*&%=<>!?|~^"));
 
 var RE_HEX_NUMBER = /^0x[0-9a-f]+$/i;
 var RE_OCT_NUMBER = /^0[0-7]+$/;
-var RE_DEC_NUMBER = /^\d*\.?\d*(?:e[+-]?\d*(?:\d\.?|\.?\d)\d*)?$/i;
 
 var OPERATORS = makePredicate([
     "in",
@@ -182,7 +181,7 @@ function parse_js_number(num) {
         return parseInt(num.substr(2), 16);
     } else if (RE_OCT_NUMBER.test(num)) {
         return parseInt(num.substr(1), 8);
-    } else if (RE_DEC_NUMBER.test(num)) {
+    } else {
         return parseFloat(num);
     }
 };