{
  "original_problem": {
    "instance_id": "django__django-15789",
    "repo": "django/django",
    "created_at": "2022-06-23T08:59:04Z",
    "problem_statement": "Add an encoder parameter to django.utils.html.json_script().\nDescription\n\t\nI have a use case where I want to customize the JSON encoding of some values to output to the template layer. It looks like django.utils.html.json_script is a good utility for that, however the JSON encoder is hardcoded to DjangoJSONEncoder. I think it would be nice to be able to pass a custom encoder class.\nBy the way, django.utils.html.json_script is not documented (only its template filter counterpart is), would it be a good thing to add to the docs?\n",
    "patch": "diff --git a/django/utils/html.py b/django/utils/html.py\n--- a/django/utils/html.py\n+++ b/django/utils/html.py\n@@ -59,7 +59,7 @@ def escapejs(value):\n }\n \n \n-def json_script(value, element_id=None):\n+def json_script(value, element_id=None, encoder=None):\n     \"\"\"\n     Escape all the HTML/XML special characters with their unicode escapes, so\n     value is safe to be output anywhere except for inside a tag attribute. Wrap\n@@ -67,7 +67,9 @@ def json_script(value, element_id=None):\n     \"\"\"\n     from django.core.serializers.json import DjangoJSONEncoder\n \n-    json_str = json.dumps(value, cls=DjangoJSONEncoder).translate(_json_script_escapes)\n+    json_str = json.dumps(value, cls=encoder or DjangoJSONEncoder).translate(\n+        _json_script_escapes\n+    )\n     if element_id:\n         template = '<script id=\"{}\" type=\"application/json\">{}</script>'\n         args = (element_id, mark_safe(json_str))\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_27935",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about index name length constraints, unrelated to JSON encoding or parameter customization."
      },
      {
        "idx": 2,
        "id": "similar_32191",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue deals with cookie compliance, which is unrelated to JSON encoding or parameter customization."
      },
      {
        "idx": 3,
        "id": "similar_29019",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue involves user model field handling, not related to JSON encoding or parameter customization."
      },
      {
        "idx": 4,
        "id": "similar_26253",
        "decision": "Not useful",
        "confidence": "High",
        "reason": "The issue is about template handling errors, unrelated to JSON encoding or parameter customization."
      },
      {
        "idx": 5,
        "id": "similar_29791",
        "decision": "Useful",
        "confidence": "Medium",
        "reason": "Both issues involve ensuring that configuration parameters are respected in function behavior."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "BrinIndex crashes if name  > 30 characters",
        "issue_body": "BrinIndex.suffix ( django.contrib.postgres.indexes) longer 3 char, but Index.set_name_with_model method allowed 3 char in suffix\nAssertionError: Index too long for multiple database support. Is self.suffix longer than 3 characters?",
        "issue_id": 27935,
        "pr_number": 8213,
        "pr_title": "Refs #27935 -- Fixed BrinIndex.max_name_length if a project's default database isn't PostgreSQL.",
        "pr_body": "",
        "issue_closed_at": "2017-03-20T10:30:05",
        "base_commit": "6cb0a3ac2836c044987f7a0cca0d1e99d52e002e"
      },
      "summary": "### Summary:\n\nThis issue is related to a bug in the Django framework, specifically within the `BrinIndex` class of the `django.contrib.postgres.indexes` module. The bug causes a crash when the `BrinIndex` name exceeds a certain length, specifically more than 30 characters. This problem arises because the `Index.set_name_with_model` method allows a suffix longer than the intended limit of 3 characters, leading to an `AssertionError` due to the index name being too long for compatibility with multiple database support.\n\nKey symptoms and behaviors observed include the application crashing with an `AssertionError` when attempting to create or use a `BrinIndex` with a name exceeding the allowed length. The error message indicates that the `self.suffix` is longer than the permissible limit, highlighting a mismatch between the intended constraints and the actual implementation.\n\nThe affected component is the `django.contrib.postgres.indexes` module, specifically the `BrinIndex` class. This issue could potentially impact applications that rely on the PostgreSQL database and use the `BrinIndex` feature within Django, particularly when dealing with longer index names.\n\nThe potential impact of this issue is significant for applications that need to maintain compatibility across multiple databases and rely on index naming conventions. It may cause application downtime or data integrity issues if not addressed.\n\nRelevant technical details include the need for stricter validation of index name lengths within the Django framework to prevent such crashes. The fix involves updating the logic in the `BrinIndex.get_sql_create_template_values` function to ensure that the index name adheres to the length constraints.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: BrinIndex crashes if name  > 30 characters\n\nBody:\nBrinIndex.suffix ( django.contrib.postgres.indexes) longer 3 char, but Index.set_name_with_model method allowed 3 char in suffix\nAssertionError: Index too long for multiple database support. Is self.suffix longer than 3 characters?\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/contrib/postgres/indexes.py\n  line: line 1\n  function: BrinIndex.get_sql_create_template_values\n"
    },
    {
      "similar_issue": {
        "issue_title": "Not RFC 6265 compliant cookies in contrib.messages.",
        "issue_body": "Hi\nA Customer of mine is using a WAF which is handling Cookies as it is described tin the RFC:\n​\nhttps://tools.ietf.org/html/rfc6265\nThe issue now is that Django is trying to use an escape-character in cookie-Values which is not supported in the RFC\nan example of such a cookie:\nmessages=\\\"123\\\\\\\"NOTRECEIVED\\\"\"\nPlease consider to get this fixed so there can be a protection of this system.\nRegards,\nNico",
        "issue_id": 32191,
        "pr_number": 13800,
        "pr_title": "Fixed #32191 -- Made CookieStorage use RFC 6265 compliant format.",
        "pr_body": "Continues work by Florian Apolloner in this [PR](https://github.com/django/django/pull/13793).\r\nThe aim is to make messages, when stored in cookies, compliant with RFC6265 which defines allowed characters for cookies. It does this by base64 encoding them, and then to reduce their size, it compresses them using zlib.\r\nThis fix is achieved by introducing `sign_object` and `unsign_object` into the base signer class.",
        "issue_closed_at": "2021-01-07T06:20:56",
        "base_commit": "3eb98743dcaa0b7abd2d5832cba8cc9cb586a964"
      },
      "summary": "### Summary: This issue pertains to non-compliance with RFC 6265 standards in the handling of cookies within the Django framework's messaging system. Specifically, the problem arises from the use of escape characters in cookie values, which contradicts the specifications outlined in RFC 6265. This non-compliance can lead to issues when interacting with systems that strictly adhere to the RFC standards, such as Web Application Firewalls (WAFs), which may reject such improperly formatted cookies.\n\n1. **Problem description in general terms:** The problem involves the use of escape characters in cookie values within a software framework, which is not in line with established standards for cookie formatting.\n\n2. **Key symptoms and behaviors observed:** The primary symptom is the rejection of cookies by systems that enforce compliance with RFC 6265, potentially causing application errors or failures in communication.\n\n3. **Affected components or systems:** The affected component is the Django framework, specifically its message storage mechanism that utilizes cookies. The issue impacts any setup using Django's messaging system in conjunction with strict cookie-handling systems like WAFs.\n\n4. **Potential impact or severity:** The severity of this issue is significant in environments where strict compliance with RFC 6265 is enforced, as it could lead to broken functionality or security measures being bypassed.\n\n5. **Relevant technical details abstracted for broader understanding:** The technical issue is rooted in the implementation of cookie encoding and decoding processes within Django's message storage system. The fix involves modifications to the encoding and decoding functions to ensure compliance with cookie standards, thereby preventing the use of unsupported escape sequences in cookie values.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Not RFC 6265 compliant cookies in contrib.messages.\n\nBody:\nHi\nA Customer of mine is using a WAF which is handling Cookies as it is described tin the RFC:\n​\nhttps://tools.ietf.org/html/rfc6265\nThe issue now is that Django is trying to use an escape-character in cookie-Values which is not supported in the RFC\nan example of such a cookie:\nmessages=\\\"123\\\\\\\"NOTRECEIVED\\\"\"\nPlease consider to get this fixed so there can be a protection of this system.\nRegards,\nNico\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/contrib/messages/storage/cookie.py\n  class: MessageEncoder\n  function: MessageDecoder.decode\n  function: CookieStorage._encode\n  function: CookieStorage._decode\n"
    },
    {
      "similar_issue": {
        "issue_title": "createsuperuser crashes if a ManyToManyField is in REQUIRED_FIELDS",
        "issue_body": "I've defined a custom user model with a ManyToMany field.\nWhen running\nmanage.py createsuperuser\nI receive the following error after entering the user's email address:\nTraceback (most recent call last):\n  File \"./manage.py\", line 22, in <module>\n    execute_from_command_line(sys.argv)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/core/management/__init__.py\", line 371, in execute_from_command_line\n    utility.execute()\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/core/management/__init__.py\", line 365, in execute\n    self.fetch_command(subcommand).run_from_argv(self.argv)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/core/management/base.py\", line 288, in run_from_argv\n    self.execute(*args, **cmd_options)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/contrib/auth/management/commands/createsuperuser.py\", line 59, in execute\n    return super().execute(*args, **options)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/core/management/base.py\", line 335, in execute\n    output = self.handle(*args, **options)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/contrib/auth/management/commands/createsuperuser.py\", line 133, in handle\n    ) if field.remote_field else '',\nAttributeError: 'ManyToManyRel' object has no attribute 'field_name'\nModels\nMy custom user model is defined as such (relevant pieces only included):\nclass OrgUser(AbstractBaseUser, PermissionsMixin):\n\temail = models.EmailField(\n\t\tverbose_name='email address',\n\t\tmax_length=255,\n\t\tunique=True,\n\t)\n\torgs = models.ManyToManyField(Organisation)\n\tUSERNAME_FIELD = 'email'\n\tREQUIRED_FIELDS = ['orgs']\n        objects = OrgUserManager()\nand Organisations\nclass Organisation(models.Model):\n\tname = models.CharField(max_length=60)\n\n\tdef __str__(self):\n\t\treturn self.name\nIt seems that if I remove the need for the Orgs to be a\nREQUIRED_FIELD\nthe issue goes away. However, it's central to my project and needs to be defined on every user.\nHappy to update the ticket with any other code snippets if required.",
        "issue_id": 29019,
        "pr_number": 11615,
        "pr_title": "Fixed #29019 -- Added ManyToManyField support to REQUIRED_FIELDS.",
        "pr_body": "[ticket 29019](https://code.djangoproject.com/ticket/29019)",
        "issue_closed_at": "2019-08-26T08:17:38",
        "base_commit": "5dac63bb844d0a976e1dd1591a323c5ba9674a97"
      },
      "summary": "### Summary:\nThis issue is a software bug encountered when using a custom user model with Django's `createsuperuser` management command. The problem arises when a `ManyToManyField` is included in the `REQUIRED_FIELDS` attribute of the user model. Specifically, the error occurs during the execution of the `createsuperuser` command, resulting in an `AttributeError` because the system attempts to access a non-existent attribute `field_name` on a `ManyToManyRel` object. \n\n1. **Problem Description in General Terms:**\n   The problem involves an incompatibility between Django's user management command and custom user models that include `ManyToManyField` in their `REQUIRED_FIELDS`. This leads to an error when attempting to create a superuser account.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - The `manage.py createsuperuser` command crashes with an `AttributeError`.\n   - The traceback indicates a failure in processing the `ManyToManyField` during superuser creation.\n   - The error occurs specifically when entering the user's email address.\n\n3. **Affected Components or Systems:**\n   - Django's `createsuperuser` management command.\n   - Custom user models using `ManyToManyField` in `REQUIRED_FIELDS`.\n\n4. **Potential Impact or Severity:**\n   - This issue prevents the creation of superuser accounts when using custom user models with specific field configurations.\n   - It can be a significant blocker for projects that rely on custom user models with mandatory many-to-many relationships.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The issue is linked to Django's management command logic that does not handle `ManyToManyField` correctly when included in `REQUIRED_FIELDS`.\n   - The problem can be temporarily bypassed by removing the `ManyToManyField` from `REQUIRED_FIELDS`, but this might not be feasible for projects that require it.\n   - The fix involves modifying the `createsuperuser` command's handling of field inputs, particularly by adjusting how it processes fields with remote relationships.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: createsuperuser crashes if a ManyToManyField is in REQUIRED_FIELDS\n\nBody:\nI've defined a custom user model with a ManyToMany field.\nWhen running\nmanage.py createsuperuser\nI receive the following error after entering the user's email address:\nTraceback (most recent call last):\n  File \"./manage.py\", line 22, in <module>\n    execute_from_command_line(sys.argv)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/core/management/__init__.py\", line 371, in execute_from_command_line\n    utility.execute()\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/core/management/__init__.py\", line 365, in execute\n    self.fetch_command(subcommand).run_from_argv(self.argv)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/core/management/base.py\", line 288, in run_from_argv\n    self.execute(*args, **cmd_options)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/contrib/auth/management/commands/createsuperuser.py\", line 59, in execute\n    return super().execute(*args, **options)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/core/management/base.py\", line 335, in execute\n    output = self.handle(*args, **options)\n  File \"/Users/jkirsop/Development/artemis/venv/lib/python3.6/site-packages/django/contrib/auth/management/commands/createsuperuser.py\", line 133, in handle\n    ) if field.remote_field else '',\nAttributeError: 'ManyToManyRel' object has no attribute 'field_name'\nModels\nMy custom user model is defined as such (relevant pieces only included):\nclass OrgUser(AbstractBaseUser, PermissionsMixin):\n\temail = models.EmailField(\n\t\tverbose_name='email address',\n\t\tmax_length=255,\n\t\tunique=True,\n\t)\n\torgs = models.ManyToManyField(Organisation)\n\tUSERNAME_FIELD = 'email'\n\tREQUIRED_FIELDS = ['orgs']\n        objects = OrgUserManager()\nand Organisations\nclass Organisation(models.Model):\n\tname = models.CharField(max_length=60)\n\n\tdef __str__(self):\n\t\treturn self.name\nIt seems that if I remove the need for the Orgs to be a\nREQUIRED_FIELD\nthe issue goes away. However, it's central to my project and needs to be defined on every user.\nHappy to update the ticket with any other code snippets if required.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/contrib/auth/management/commands/createsuperuser.py\n  function: Command.add_arguments\n  function: Command.handle\n  function: Command.handle\n  function: Command._get_input_message\n"
    },
    {
      "similar_issue": {
        "issue_title": "Deprecation for TemplateResponse and SimpleTemplateResponse accepting django.template.Template is broken",
        "issue_body": "When\nTemplateResponse\nor\nSimpleTemplateResponse\nare called, a TypeError is thrown.\nThis is because their\n__init__() creates a\nBackendTemplate` giving only one argument to the constructor.\nThe resulting error is obviously confusing and obfuscates the warning.\nThe attached patch addresses the issue, although I am unsure whether one should assume, by default, that a DjangoTemplate was given.",
        "issue_id": 26253,
        "pr_number": 6177,
        "pr_title": "Fixed #26253 -- Fixed crashing deprecation shims in SimpleTemplateResponse.",
        "pr_body": "https://code.djangoproject.com/ticket/26253\n",
        "issue_closed_at": "2016-02-22T16:07:54",
        "base_commit": "174811c5538c8c0b8f66089b31686e80d2bc7d3b"
      },
      "summary": "### Summary: This issue is related to a malfunction in the Django web framework where the classes `TemplateResponse` and `SimpleTemplateResponse` fail to handle the `django.template.Template` object correctly. The problem arises during the initialization of these classes, where a `TypeError` is triggered due to incorrect construction of a `BackendTemplate` object. This error not only disrupts the normal operation by causing a crash but also obscures the intended deprecation warning that should guide developers towards the correct usage. The affected components are the `__init__` methods in `TemplateResponse` and `_resolve_template` in `SimpleTemplateResponse`, located in the `django/template/response.py` file. The impact of this issue is significant as it can lead to application errors and confusion among developers who rely on these classes for rendering templates. Technical resolution involves correcting the constructor call to ensure compatibility and proper functioning without assuming a specific template type by default.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Deprecation for TemplateResponse and SimpleTemplateResponse accepting django.template.Template is broken\n\nBody:\nWhen\nTemplateResponse\nor\nSimpleTemplateResponse\nare called, a TypeError is thrown.\nThis is because their\n__init__() creates a\nBackendTemplate` giving only one argument to the constructor.\nThe resulting error is obviously confusing and obfuscates the warning.\nThe attached patch addresses the issue, although I am unsure whether one should assume, by default, that a DjangoTemplate was given.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/template/response.py\n  line: line 4\n  function: TemplateResponse.__init__\n  function: SimpleTemplateResponse._resolve_template\n"
    },
    {
      "similar_issue": {
        "issue_title": "Engine.render_to_string() should honor the autoescape attribute",
        "issue_body": "In\nEngine.render_to_string\n, a\nContext\nis created without specifying the engine\nautoescape\nattribute. So if you create en engine with\nautoescape=False\nand then call its\nrender_to_string()\nmethod, the result will always be autoescaped. It was probably overlooked in\n[19a5f6da329d58653bcda85]\n.",
        "issue_id": 29791,
        "pr_number": 11119,
        "pr_title": "Fixed #29791 -- Honor engine's autoescape attribute in render_to_string",
        "pr_body": "Passed down autoescape value from Engine to Context in Engine.render_to_string.",
        "issue_closed_at": "2019-03-25T17:26:24",
        "base_commit": "d4df5e1b0b1c643fe0fc521add0236764ec8e92a"
      },
      "summary": "### Summary:\n\nThis issue pertains to the functionality of the `Engine.render_to_string` method within the Django templating engine. The problem arises because the method does not respect the `autoescape` attribute specified during the creation of an `Engine` instance. This oversight leads to inconsistent behavior, particularly when an engine is configured with `autoescape=False`, yet the `render_to_string()` method results in the output being autoescaped regardless. This inconsistency likely stems from an omission in a previous code update identified by a specific commit hash.\n\nKey symptoms include the unexpected autoescaping of output strings when the `autoescape` attribute is deliberately set to `False`. This behavior affects the `render_to_string` function within the Django template engine, which is responsible for rendering templates to strings.\n\nThe potential impact of this issue is significant for applications relying on customized escaping behavior, as it could lead to incorrect rendering of templates and potentially expose applications to security vulnerabilities or data misrepresentation if not addressed.\n\nOverall, this issue highlights the importance of ensuring that configuration attributes like `autoescape` are consistently honored across all methods of a software component to maintain expected behavior and application integrity.",
      "prompt_used": "You are an expert in software issue reasoning analysis.\nGiven the following problem report and its fixed code elements, generate a comprehensive summary based on the entire document. Your goal is to abstract the information in the problem description into a more general description.\n\n## Original Issue Report:\nTitle: Engine.render_to_string() should honor the autoescape attribute\n\nBody:\nIn\nEngine.render_to_string\n, a\nContext\nis created without specifying the engine\nautoescape\nattribute. So if you create en engine with\nautoescape=False\nand then call its\nrender_to_string()\nmethod, the result will always be autoescaped. It was probably overlooked in\n[19a5f6da329d58653bcda85]\n.\n\n## Code elements fixed by the patch:\n{FIXED_CODE_ELEMENTS}\n\nPlease analyze the above issue report and provide a structured summary that includes:\n1. Problem description in general terms\n2. Key symptoms and behaviors observed\n3. Affected components or systems\n4. Potential impact or severity\n5. Any relevant technical details abstracted for broader understanding\n\nPlease return the summary with “### Summary:\", For example:\n### Summary: This issue is ...\n\nChanges Summary:\ndjango/template/engine.py\n  function: Engine.render_to_string\n"
    }
  ]
}