{
  "Selected_candidate": {
    "pr_number": 7471,
    "pr_title": "Fixed #26812 -- Check only path with APPEND_SLASH enabled",
    "pr_body": "",
    "issue_id": 26812,
    "issue_title": "APPEND_SLASH doesn't work with URLs that have query strings",
    "issue_body": "Hi,\nIn\nmiddleware/common.py\nthere is a code, which checks whether the slash should be appended to URL.\ndef should_redirect_with_slash(self, request):\n        \"\"\"\n        Return True if settings.APPEND_SLASH is True and appending a slash to\n        the request path turns an invalid path into a valid one.\n        \"\"\"\n\n        if settings.APPEND_SLASH and not request.get_full_path().endswith('/'):\n            urlconf = getattr(request, 'urlconf', None)\n\n            return (\n                not urlresolvers.is_valid_path(request.path_info, urlconf)\n                and urlresolvers.is_valid_path('%s/' % request.path_info, urlconf)\n            )\n        return False\nIn most cases it works fine, but it fails to append slash, when used with LOGIN_URL without slash and with \"next\" parameter. For example:\nIt works fine:\n/accounts/login/?next=/polls/3/\n-> LOGIN_URL =\n/accounts/login/\nBut this one returns 404:\n/accounts/login?next=/polls/3/\n-> LOGIN_URL =\n/accounts/login (no trailing slash).\nIt is because:\nrequest.get_full_path().endswith('/')\nchecks also query string and therefore returns true and the slash is never appended.",
    "issue_closed_at": "2016-11-06T03:38:42",
    "base_commit": "b741fe397aa567dd43d3e9dbd9fb5ecca6eab412",
    "changes": [
      {
        "file": "django/middleware/common.py",
        "type": "function",
        "name": "should_redirect_with_slash",
        "class_name": "CommonMiddleware",
        "code": "def should_redirect_with_slash(self, request):\n        \"\"\"\n        Return True if settings.APPEND_SLASH is True and appending a slash to\n        the request path turns an invalid path into a valid one.\n        \"\"\"\n        if settings.APPEND_SLASH and not request.get_full_path().endswith('/'):\n            urlconf = getattr(request, 'urlconf', None)\n            return (\n                not is_valid_path(request.path_info, urlconf) and\n                is_valid_path('%s/' % request.path_info, urlconf)\n            )\n        return False"
      }
    ]
  },
  "Justification": "Candidate A is the most relevant report as it directly deals with validation of input based on regex patterns, similar to the issue found in the CURRENT bug report regarding usernames. Both involve regular expression logic to validate specific inputs—Candidate A focuses on ensuring URLs have the correct structure while the CURRENT bug report addresses username validation to exclude newline characters. The structural similarity in the regex handling and the need for accurate validation logic makes Candidate A particularly helpful in diagnosing and fixing the CURRENT bug.",
  "instance_id": "django__django-11099",
  "repo": "django/django",
  "created_at": "2019-03-20T03:46:18Z",
  "problem_statement": "UsernameValidator allows trailing newline in usernames\nDescription\n\t\nASCIIUsernameValidator and UnicodeUsernameValidator use the regex \nr'^[\\w.@+-]+$'\nThe intent is to only allow alphanumeric characters as well as ., @, +, and -. However, a little known quirk of Python regexes is that $ will also match a trailing newline. Therefore, the user name validators will accept usernames which end with a newline. You can avoid this behavior by instead using \\A and \\Z to terminate regexes. For example, the validator regex could be changed to\nr'\\A[\\w.@+-]+\\Z'\nin order to reject usernames that end with a newline.\nI am not sure how to officially post a patch, but the required change is trivial - using the regex above in the two validators in contrib.auth.validators.\n",
  "patch": "diff --git a/django/contrib/auth/validators.py b/django/contrib/auth/validators.py\n--- a/django/contrib/auth/validators.py\n+++ b/django/contrib/auth/validators.py\n@@ -7,7 +7,7 @@\n \n @deconstructible\n class ASCIIUsernameValidator(validators.RegexValidator):\n-    regex = r'^[\\w.@+-]+$'\n+    regex = r'^[\\w.@+-]+\\Z'\n     message = _(\n         'Enter a valid username. This value may contain only English letters, '\n         'numbers, and @/./+/-/_ characters.'\n@@ -17,7 +17,7 @@ class ASCIIUsernameValidator(validators.RegexValidator):\n \n @deconstructible\n class UnicodeUsernameValidator(validators.RegexValidator):\n-    regex = r'^[\\w.@+-]+$'\n+    regex = r'^[\\w.@+-]+\\Z'\n     message = _(\n         'Enter a valid username. This value may contain only letters, '\n         'numbers, and @/./+/-/_ characters.'\n"
}