Reject all expressions with __ in them.
authorJoe Wreschnig <joe.wreschnig@gmail.com>
Sun, 10 Jun 2012 08:42:21 +0000 (10:42 +0200)
committerJoe Wreschnig <joe.wreschnig@gmail.com>
Sun, 10 Jun 2012 08:42:21 +0000 (10:42 +0200)
bulletml/expr.py

index 385b31b..c7d4098 100644 (file)
@@ -38,6 +38,12 @@ class NumberDef(object):
             expr = expr.string
         except AttributeError:
             pass
+        try:
+            if "__" in expr:
+                # nedbatchelder.com/blog/201206/eval_really_is_dangerous.html
+                raise ExprError(expr)
+        except TypeError:
+            pass
         self.string = expr = str(expr)
         repl = lambda match: "params[%d]" % (int(match.group()[1:]) - 1)
         expr = re.sub(r"\$\d+", repl, expr.lower())