From 9a5ebbcac9480c265e8f736ec3bceb2e8a3546b9 Mon Sep 17 00:00:00 2001 From: Luke Plant Date: Fri, 25 Feb 2011 09:45:54 +0000 Subject: [PATCH] [1.2.X] Fixed #15493 - csrf_migration_helper.py parsing fix. Thanks to 'john' for the patch. Backport of [15647] from trunk. git-svn-id: http://code.djangoproject.com/svn/django/branches/releases/1.2.X@15648 bcc190cf-cafb-0310-a4f2-bffc1f526a37 --- extras/csrf_migration_helper.py | 25 ++++++++++++++++--------- 1 file changed, 16 insertions(+), 9 deletions(-) mode change 100644 => 100755 extras/csrf_migration_helper.py diff --git a/extras/csrf_migration_helper.py b/extras/csrf_migration_helper.py old mode 100644 new mode 100755 index 6416193c49..6aaf6b433d --- a/extras/csrf_migration_helper.py +++ b/extras/csrf_migration_helper.py @@ -41,10 +41,6 @@ # loaders are out of the picture, because there is no way to ask them to # return all templates. # -# - If you put the {% csrf_token %} tag on the same line as the
tag it -# will be detected, otherwise it will be assumed that the form does not have -# the token. -# # - It's impossible to programmatically determine which forms should and should # not have the token added. The developer must decide when to do this, # ensuring that the token is only added to internally targetted forms. @@ -138,6 +134,7 @@ python csrf_migration_helper.py [--settings=path.to.your.settings] /path/to/pyth _POST_FORM_RE = \ re.compile(r'(]*\bmethod\s*=\s*(\'|"|)POST(\'|"|)\b[^>]*>)', re.IGNORECASE) +_FORM_CLOSE_RE = re.compile(r'') _TOKEN_RE = re.compile('\{% csrf_token') def get_template_dirs(): @@ -190,12 +187,22 @@ class Template(object): Get information about any POST forms in the template. Returns [(linenumber, csrf_token added)] """ - matches = [] + forms = {} + form_line = 0 for ln, line in enumerate(self.content.split("\n")): - m = _POST_FORM_RE.search(line) - if m is not None: - matches.append((ln + 1, _TOKEN_RE.search(line) is not None)) - return matches + if not form_line and _POST_FORM_RE.search(line): + # record the form with no CSRF token yet + form_line = ln + 1 + forms[form_line] = False + if form_line and _TOKEN_RE.search(line): + # found the CSRF token + forms[form_line] = True + form_line = 0 + if form_line and _FORM_CLOSE_RE.search(line): + # no token found by form closing tag + form_line = 0 + + return forms.items() def includes_template(self, t): """