{
  "instance_id": "django__django-14411",
  "repo": "django/django",
  "created_at": "2021-05-19T04:05:47Z",
  "problem_statement": "Label for ReadOnlyPasswordHashWidget points to non-labelable element.\nDescription\n\t \n\t\t(last modified by David Sanders)\n\t \nIn the admin, the label element for the ReadOnlyPasswordHashWidget widget has a 'for' attribute which points to a non-labelable element, since the widget just renders text, not an input. There's no labelable element for the widget, so the label shouldn't have a 'for' attribute.\n",
  "patch": "diff --git a/django/contrib/auth/forms.py b/django/contrib/auth/forms.py\n--- a/django/contrib/auth/forms.py\n+++ b/django/contrib/auth/forms.py\n@@ -50,6 +50,9 @@ def get_context(self, name, value, attrs):\n         context['summary'] = summary\n         return context\n \n+    def id_for_label(self, id_):\n+        return None\n+\n \n class ReadOnlyPasswordHashField(forms.Field):\n     widget = ReadOnlyPasswordHashWidget\n",
  "similar_bug_items": [
    {
      "pr_number": 8401,
      "pr_title": "Fixed #28040 -- Updated SplitArrayWidget to use template-based widget rendering.",
      "pr_body": "https://code.djangoproject.com/ticket/28040",
      "issue_id": 28040,
      "issue_title": "Update SplitArrayWidget to use template-based widget rendering",
      "issue_body": "",
      "issue_closed_at": "2017-04-29T18:00:32",
      "base_commit": "c920db1e57bf6bec65b075fd0baac72e13db9919",
      "changes": [
        {
          "file": "django/contrib/postgres/forms/array.py",
          "type": "line",
          "name": "line 6",
          "code": "    ArrayMaxLengthValidator, ArrayMinLengthValidator,\n)\nfrom django.core.exceptions import ValidationError\nfrom django.utils.safestring import mark_safe\nfrom django.utils.translation import gettext_lazy as _\n\nfrom ..utils import prefix_validation_error"
        },
        {
          "file": "django/contrib/postgres/forms/array.py",
          "type": "function",
          "name": "run_validators",
          "class_name": "SimpleArrayField",
          "code": "def run_validators(self, value):\n        super().run_validators(value)\n        errors = []\n        for index, item in enumerate(value):\n            try:\n                self.base_field.run_validators(item)\n            except ValidationError as error:\n                errors.append(prefix_validation_error(\n                    error,\n                    prefix=self.error_messages['item_invalid'],\n                    code='item_invalid',\n                    params={'nth': index},\n                ))\n        if errors:\n            raise ValidationError(errors)"
        },
        {
          "file": "django/contrib/postgres/forms/array.py",
          "type": "function",
          "name": "id_for_label",
          "class_name": "SplitArrayWidget",
          "code": "def id_for_label(self, id_):\n        # See the comment for RadioSelect.id_for_label()\n        if id_:\n            id_ += '_0'\n        return id_"
        },
        {
          "file": "django/contrib/postgres/forms/array.py",
          "type": "function",
          "name": "render",
          "class_name": "SplitArrayWidget",
          "code": "def render(self, name, value, attrs=None, renderer=None):\n        if self.is_localized:\n            self.widget.is_localized = self.is_localized\n        value = value or []\n        output = []\n        final_attrs = self.build_attrs(attrs)\n        id_ = final_attrs.get('id')\n        for i in range(max(len(value), self.size)):\n            try:\n                widget_value = value[i]\n            except IndexError:\n                widget_value = None\n            if id_:\n                final_attrs = dict(final_attrs, id='%s_%s' % (id_, i))\n            output.append(self.widget.render(name + '_%s' % i, widget_value, final_attrs, renderer))\n        return mark_safe(self.format_output(output))"
        }
      ]
    },
    {
      "pr_number": 11034,
      "pr_title": "Fixed #30221 -- Made label suffix of admin's read-only fields translatable.",
      "pr_body": "https://code.djangoproject.com/ticket/30221",
      "issue_id": 30221,
      "issue_title": "Disabled field in admin use hard coded label_suffix",
      "issue_body": "",
      "issue_closed_at": "2019-02-28T11:36:52",
      "base_commit": "25e724a5d6e331d2d73050d6dcdf2e8593c3aebf",
      "changes": [
        {
          "file": "django/contrib/admin/helpers.py",
          "type": "function",
          "name": "label_tag",
          "class_name": "AdminReadonlyField",
          "code": "def label_tag(self):\n        attrs = {}\n        if not self.is_first:\n            attrs[\"class\"] = \"inline\"\n        label = self.field['label']\n        return format_html('<label{}>{}:</label>', flatatt(attrs), capfirst(label))"
        }
      ]
    },
    {
      "pr_number": 3503,
      "pr_title": "Fixed #23795 -- Fixed a regression in custom form fields",
      "pr_body": "Custom form fields having a `queryset` attribute but no\n`limit_choices_to` could no longer be used in ModelForms.\n\nRefs #2445.\n\nThanks to @artscoop for the report.\n",
      "issue_id": 23795,
      "issue_title": "Django form fields : limit_choices_to should not be mandatory with queryset",
      "issue_body": "",
      "issue_closed_at": "2014-11-12T15:39:19",
      "base_commit": "11b7680d0e640a7d4b1c942f74e9197b6ec924b1",
      "changes": [
        {
          "file": "django/forms/fields.py",
          "type": "function",
          "name": "widget_attrs",
          "class_name": "DecimalField",
          "code": "def widget_attrs(self, widget):\n        attrs = super(DecimalField, self).widget_attrs(widget)\n        if isinstance(widget, NumberInput) and 'step' not in widget.attrs:\n            if self.decimal_places is not None:\n                # Use exponential notation for small values since they might\n                # be parsed as 0 otherwise. ref #20765\n                step = str(Decimal('1') / 10 ** self.decimal_places).lower()\n            else:\n                step = 'any'\n            attrs.setdefault('step', step)\n        return attrs"
        },
        {
          "file": "django/forms/models.py",
          "type": "function",
          "name": "__init__",
          "class_name": "ModelMultipleChoiceField",
          "code": "def __init__(self, queryset, cache_choices=None, required=True,\n                 widget=None, label=None, initial=None,\n                 help_text='', *args, **kwargs):\n        super(ModelMultipleChoiceField, self).__init__(queryset, None,\n            cache_choices, required, widget, label, initial, help_text,\n            *args, **kwargs)"
        },
        {
          "file": "django/forms/models.py",
          "type": "function",
          "name": "__init__",
          "class_name": "ModelMultipleChoiceField",
          "code": "def __init__(self, queryset, cache_choices=None, required=True,\n                 widget=None, label=None, initial=None,\n                 help_text='', *args, **kwargs):\n        super(ModelMultipleChoiceField, self).__init__(queryset, None,\n            cache_choices, required, widget, label, initial, help_text,\n            *args, **kwargs)"
        }
      ]
    },
    {
      "pr_number": 8362,
      "pr_title": "Fixed #28058 -- Restored empty BoundFields evaluating to True.",
      "pr_body": "https://code.djangoproject.com/ticket/28058",
      "issue_id": 28058,
      "issue_title": "Empty Select widget (no choices) evaluates to False",
      "issue_body": "",
      "issue_closed_at": "2017-04-17T07:49:12",
      "base_commit": "e5dce7b0fbd2965e524ce97114f501319ec2bb6f",
      "changes": [
        {
          "file": "django/forms/boundfield.py",
          "type": "function",
          "name": "subwidgets",
          "class_name": "BoundField",
          "code": "def subwidgets(self):\n        \"\"\"\n        Most widgets yield a single subwidget, but others like RadioSelect and\n        CheckboxSelectMultiple produce one subwidget for each choice.\n\n        This property is cached so that only one database query occurs when\n        rendering ModelChoiceFields.\n        \"\"\"\n        id_ = self.field.widget.attrs.get('id') or self.auto_id\n        attrs = {'id': id_} if id_ else {}\n        attrs = self.build_widget_attrs(attrs)\n        return list(\n            BoundWidget(self.field.widget, widget, self.form.renderer)\n            for widget in self.field.widget.subwidgets(self.html_name, self.value(), attrs=attrs)\n        )"
        }
      ]
    },
    {
      "pr_number": 6309,
      "pr_title": "Fixed #25232, #24987 -- Made ModelBackend reject inactive users.",
      "pr_body": "https://code.djangoproject.com/ticket/25232\nhttps://code.djangoproject.com/ticket/24987\n\nUpdated from https://github.com/django/django/pull/6090\n",
      "issue_id": 24987,
      "issue_title": "Remove test client login()'s hardcoded rejection of inactive users",
      "issue_body": "",
      "issue_closed_at": "2016-03-23T08:21:35",
      "base_commit": "1555d50ea40f22524b58e71bf15f3fc69a7c9591",
      "changes": [
        {
          "file": "django/contrib/auth/backends.py",
          "type": "function",
          "name": "authenticate",
          "class_name": "RemoteUserBackend",
          "code": "def authenticate(self, remote_user):\n        \"\"\"\n        The username passed as ``remote_user`` is considered trusted.  This\n        method simply returns the ``User`` object with the given username,\n        creating a new ``User`` object if ``create_unknown_user`` is ``True``.\n\n        Returns None if ``create_unknown_user`` is ``False`` and a ``User``\n        object with the given username is not found in the database.\n        \"\"\"\n        if not remote_user:\n            return\n        user = None\n        username = self.clean_username(remote_user)\n\n        UserModel = get_user_model()\n\n        # Note that this could be accomplished in one try-except clause, but\n        # instead we use get_or_create when creating unknown users since it has\n        # built-in safeguards for multiple threads.\n        if self.create_unknown_user:\n            user, created = UserModel._default_manager.get_or_create(**{\n                UserModel.USERNAME_FIELD: username\n            })\n            if created:\n                user = self.configure_user(user)\n        else:\n            try:\n                user = UserModel._default_manager.get_by_natural_key(username)\n            except UserModel.DoesNotExist:\n                pass\n        return user"
        },
        {
          "file": "django/contrib/auth/backends.py",
          "type": "function",
          "name": "has_module_perms",
          "class_name": "ModelBackend",
          "code": "def has_module_perms(self, user_obj, app_label):\n        \"\"\"\n        Returns True if user_obj has any permissions in the given app_label.\n        \"\"\"\n        if not user_obj.is_active:\n            return False\n        for perm in self.get_all_permissions(user_obj):\n            if perm[:perm.index('.')] == app_label:\n                return True\n        return False"
        },
        {
          "file": "django/contrib/auth/backends.py",
          "type": "function",
          "name": "authenticate",
          "class_name": "RemoteUserBackend",
          "code": "def authenticate(self, remote_user):\n        \"\"\"\n        The username passed as ``remote_user`` is considered trusted.  This\n        method simply returns the ``User`` object with the given username,\n        creating a new ``User`` object if ``create_unknown_user`` is ``True``.\n\n        Returns None if ``create_unknown_user`` is ``False`` and a ``User``\n        object with the given username is not found in the database.\n        \"\"\"\n        if not remote_user:\n            return\n        user = None\n        username = self.clean_username(remote_user)\n\n        UserModel = get_user_model()\n\n        # Note that this could be accomplished in one try-except clause, but\n        # instead we use get_or_create when creating unknown users since it has\n        # built-in safeguards for multiple threads.\n        if self.create_unknown_user:\n            user, created = UserModel._default_manager.get_or_create(**{\n                UserModel.USERNAME_FIELD: username\n            })\n            if created:\n                user = self.configure_user(user)\n        else:\n            try:\n                user = UserModel._default_manager.get_by_natural_key(username)\n            except UserModel.DoesNotExist:\n                pass\n        return user"
        },
        {
          "file": "django/contrib/auth/backends.py",
          "type": "function",
          "name": "configure_user",
          "class_name": "RemoteUserBackend",
          "code": "def configure_user(self, user):\n        \"\"\"\n        Configures a user after creation and returns the updated user.\n\n        By default, returns the user unmodified.\n        \"\"\"\n        return user"
        }
      ]
    }
  ]
}