{
  "original_problem": {
    "instance_id": "django__django-15819",
    "repo": "django/django",
    "created_at": "2022-07-04T18:29:53Z",
    "problem_statement": "inspectdb should generate related_name on same relation links.\nDescription\n\t\nHi!\nAfter models generation with inspectdb command we have issue with relations to same enities\nmodule.Model.field1: (fields.E304) Reverse accessor for 'module.Model.field1' clashes with reverse accessor for 'module.Model.field2'.\nHINT: Add or change a related_name argument to the definition for 'module.Model.field1' or 'module.Model.field2'.\n*\nMaybe we can autogenerate\nrelated_name='attribute_name'\nto all fields in model if related Model was used for this table\n",
    "patch": "diff --git a/django/core/management/commands/inspectdb.py b/django/core/management/commands/inspectdb.py\n--- a/django/core/management/commands/inspectdb.py\n+++ b/django/core/management/commands/inspectdb.py\n@@ -127,12 +127,14 @@ def table2model(table_name):\n                     yield \"# The error was: %s\" % e\n                     continue\n \n+                model_name = table2model(table_name)\n                 yield \"\"\n                 yield \"\"\n-                yield \"class %s(models.Model):\" % table2model(table_name)\n-                known_models.append(table2model(table_name))\n+                yield \"class %s(models.Model):\" % model_name\n+                known_models.append(model_name)\n                 used_column_names = []  # Holds column names used in the table so far\n                 column_to_field_name = {}  # Maps column names to names of model fields\n+                used_relations = set()  # Holds foreign relations used in the table.\n                 for row in table_description:\n                     comment_notes = (\n                         []\n@@ -186,6 +188,12 @@ def table2model(table_name):\n                             field_type = \"%s(%s\" % (rel_type, rel_to)\n                         else:\n                             field_type = \"%s('%s'\" % (rel_type, rel_to)\n+                        if rel_to in used_relations:\n+                            extra_params[\"related_name\"] = \"%s_%s_set\" % (\n+                                model_name.lower(),\n+                                att_name,\n+                            )\n+                        used_relations.add(rel_to)\n                     else:\n                         # Calling `get_field_type` to get the field type string and any\n                         # additional parameters and notes.\n"
  },
  "candidates_evaluated": 5,
  "judgment_result": {
    "candidates": [
      {
        "idx": 1,
        "id": "similar_26171",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue focuses on database indexing logic rather than model field relationship handling."
      },
      {
        "idx": 2,
        "id": "similar_23538",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue is about GIS indexing in MySQL, unrelated to model field relationship conflicts."
      },
      {
        "idx": 3,
        "id": "similar_25560",
        "decision": "Useful",
        "confidence": "High",
        "reason": "Both issues involve handling and validating the `related_name` attribute in Django models."
      },
      {
        "idx": 4,
        "id": "similar_32718",
        "decision": "Not useful",
        "confidence": "Low",
        "reason": "The issue is about file path handling, unrelated to model field relationship conflicts."
      },
      {
        "idx": 5,
        "id": "similar_31664",
        "decision": "Not useful",
        "confidence": "Medium",
        "reason": "The issue involves query filtering logic, not directly related to model field relationship handling."
      }
    ]
  },
  "raw_summaries": [
    {
      "similar_issue": {
        "issue_title": "ForeignKey with db_constraint=False doesn't generate an index on MySQL",
        "issue_body": "I have a model that does not want to use a constraint on a foreign key, but still use a database index:\nclass Category(models.Model):\n    text = models.CharField(max_length=3)\n\nclass Message(models.Model):\n    cat = models.ForeignKey(Category, db_constraint=False)\n\nclass IndexMessage(models.Model):\n    cat = models.ForeignKey(Category, db_constraint=False, db_index=True)\n\nclass StrongMessage(models.Model):\n    cat = models.ForeignKey(Category)\nThe SQLite backend generates an index on the FK column for both models:\n$ python manage.py sqlmigrate boohoo 0001_initial\nBEGIN;\n--\n-- Create model Category\n--\nCREATE TABLE \"boohoo_category\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"text\" varchar(3) NOT NULL);\n--\n-- Create model IndexMessage\n--\nCREATE TABLE \"boohoo_indexmessage\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL);\n--\n-- Create model Message\n--\nCREATE TABLE \"boohoo_message\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL);\n--\n-- Create model StrongMessage\n--\nCREATE TABLE \"boohoo_strongmessage\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL REFERENCES \"boohoo_category\" (\"id\"));\nCREATE INDEX \"boohoo_indexmessage_05e7bb57\" ON \"boohoo_indexmessage\" (\"cat_id\");\nCREATE INDEX \"boohoo_message_05e7bb57\" ON \"boohoo_message\" (\"cat_id\");\nCREATE INDEX \"boohoo_strongmessage_05e7bb57\" ON \"boohoo_strongmessage\" (\"cat_id\");\n\nCOMMIT;\nWith the MySQL backend, this does not create an index on the FK:\n$ python manage.py sqlmigrate boohoo 0001_initial\nBEGIN;\n--\n-- Create model Category\n--\nCREATE TABLE `boohoo_category` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `text` varchar(3) NOT NULL);\n--\n-- Create model IndexMessage\n--\nCREATE TABLE `boohoo_indexmessage` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\n--\n-- Create model Message\n--\nCREATE TABLE `boohoo_message` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\n--\n-- Create model StrongMessage\n--\nCREATE TABLE `boohoo_strongmessage` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\nALTER TABLE `boohoo_strongmessage` ADD CONSTRAINT `boohoo_strongmessage_cat_id_c843b68a_fk_boohoo_category_id` FOREIGN KEY (`cat_id`) REFERENCES `boohoo_category` (`id`);\n\nCOMMIT;\nI would think that specifying db_constraint=false would only leave out the constraint, and not also the index; Especially with <field>.db_index still set to true. Adding db_index=True does not help, probably because that is the default setting on the FK field object.\nThis also applies to earlier django versions.\nA simple workaround is to use\nindex_together = (('cat', ), )\non the models.\nI'm inclined to blame this on django.db.backends.mysql.schema.DatabaseSchemaEditor#_model_indexes_sql,\nwhich may need an extra check for db_constraint being used. This fixes my problem (but changes current django behavior):\n--- django/db/backends/mysql/schema.py.orig     2016-02-03 12:01:10.000000000 +0100\n+++ django/db/backends/mysql/schema.py  2016-02-03 12:00:19.000000000 +0100\n@@ -64,7 +64,7 @@\n         )\n         if storage == \"InnoDB\":\n             for field in model._meta.local_fields:\n-                if field.db_index and not field.unique and field.get_internal_type() == \"ForeignKey\":\n+                if field.db_index and not field.unique and field.get_internal_type() == \"ForeignKey\" and field.db_constraint:\n                     # Temporary setting db_index to False (in memory) to disable\n                     # index creation for FKs (index automatically created by MySQL)\n                     field.db_index = False",
        "issue_id": 26171,
        "pr_number": 6774,
        "pr_title": "Fixed #26171 -- Made MySQL create an index on ForeignKeys with db_contraint=False.",
        "pr_body": "Refactor \"Prevented unneeded index creation on MySQL-InnoDB\" (2ceb10f)\nto avoid setting db_index = False. Check db_constraint=True before\nskipping the index creation, fixes #26171.\n",
        "issue_closed_at": "2016-06-28T07:19:11",
        "base_commit": "5fe1c92250017110430c7c2153cfd8776e4c7064"
      },
      "summary": "### Summary: This issue concerns the behavior of database indexing in Django when using the MySQL backend for models with foreign keys. Specifically, when a `ForeignKey` field in a Django model is defined with `db_constraint=False` and `db_index=True`, an index is not generated on MySQL, contrary to expectations. This behavior differs from the SQLite backend, where an index is created under similar conditions. The issue potentially affects data retrieval efficiency and integrity checks within applications using MySQL. The problem is traced to Django's schema generation logic, specifically within the `DatabaseSchemaEditor` class in the MySQL backend, where the index creation logic does not account for `db_constraint=False`. A workaround involves using the `index_together` option in models to ensure indexing. The proposed fix involves modifying the schema editor code to correctly handle the absence of constraints while ensuring the index is created, impacting how Django manages database schema for MySQL backends.",
      "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: ForeignKey with db_constraint=False doesn't generate an index on MySQL\n\nBody:\nI have a model that does not want to use a constraint on a foreign key, but still use a database index:\nclass Category(models.Model):\n    text = models.CharField(max_length=3)\n\nclass Message(models.Model):\n    cat = models.ForeignKey(Category, db_constraint=False)\n\nclass IndexMessage(models.Model):\n    cat = models.ForeignKey(Category, db_constraint=False, db_index=True)\n\nclass StrongMessage(models.Model):\n    cat = models.ForeignKey(Category)\nThe SQLite backend generates an index on the FK column for both models:\n$ python manage.py sqlmigrate boohoo 0001_initial\nBEGIN;\n--\n-- Create model Category\n--\nCREATE TABLE \"boohoo_category\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"text\" varchar(3) NOT NULL);\n--\n-- Create model IndexMessage\n--\nCREATE TABLE \"boohoo_indexmessage\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL);\n--\n-- Create model Message\n--\nCREATE TABLE \"boohoo_message\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL);\n--\n-- Create model StrongMessage\n--\nCREATE TABLE \"boohoo_strongmessage\" (\"id\" integer NOT NULL PRIMARY KEY AUTOINCREMENT, \"cat_id\" integer NOT NULL REFERENCES \"boohoo_category\" (\"id\"));\nCREATE INDEX \"boohoo_indexmessage_05e7bb57\" ON \"boohoo_indexmessage\" (\"cat_id\");\nCREATE INDEX \"boohoo_message_05e7bb57\" ON \"boohoo_message\" (\"cat_id\");\nCREATE INDEX \"boohoo_strongmessage_05e7bb57\" ON \"boohoo_strongmessage\" (\"cat_id\");\n\nCOMMIT;\nWith the MySQL backend, this does not create an index on the FK:\n$ python manage.py sqlmigrate boohoo 0001_initial\nBEGIN;\n--\n-- Create model Category\n--\nCREATE TABLE `boohoo_category` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `text` varchar(3) NOT NULL);\n--\n-- Create model IndexMessage\n--\nCREATE TABLE `boohoo_indexmessage` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\n--\n-- Create model Message\n--\nCREATE TABLE `boohoo_message` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\n--\n-- Create model StrongMessage\n--\nCREATE TABLE `boohoo_strongmessage` (`id` integer AUTO_INCREMENT NOT NULL PRIMARY KEY, `cat_id` integer NOT NULL);\nALTER TABLE `boohoo_strongmessage` ADD CONSTRAINT `boohoo_strongmessage_cat_id_c843b68a_fk_boohoo_category_id` FOREIGN KEY (`cat_id`) REFERENCES `boohoo_category` (`id`);\n\nCOMMIT;\nI would think that specifying db_constraint=false would only leave out the constraint, and not also the index; Especially with <field>.db_index still set to true. Adding db_index=True does not help, probably because that is the default setting on the FK field object.\nThis also applies to earlier django versions.\nA simple workaround is to use\nindex_together = (('cat', ), )\non the models.\nI'm inclined to blame this on django.db.backends.mysql.schema.DatabaseSchemaEditor#_model_indexes_sql,\nwhich may need an extra check for db_constraint being used. This fixes my problem (but changes current django behavior):\n--- django/db/backends/mysql/schema.py.orig     2016-02-03 12:01:10.000000000 +0100\n+++ django/db/backends/mysql/schema.py  2016-02-03 12:00:19.000000000 +0100\n@@ -64,7 +64,7 @@\n         )\n         if storage == \"InnoDB\":\n             for field in model._meta.local_fields:\n-                if field.db_index and not field.unique and field.get_internal_type() == \"ForeignKey\":\n+                if field.db_index and not field.unique and field.get_internal_type() == \"ForeignKey\" and field.db_constraint:\n                     # Temporary setting db_index to False (in memory) to disable\n                     # index creation for FKs (index automatically created by MySQL)\n                     field.db_index = False\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/db/backends/base/schema.py\n  function: BaseDatabaseSchemaEditor._model_indexes_sql\n  function: BaseDatabaseSchemaEditor._model_indexes_sql\n\ndjango/db/backends/mysql/schema.py\n  function: DatabaseSchemaEditor.add_field\n"
    },
    {
      "similar_issue": {
        "issue_title": "MySQL GIS backend missing SchemaEditor",
        "issue_body": "I think this results in a missing index for GIS fields on apps that have migrations.",
        "issue_id": 23538,
        "pr_number": 3265,
        "pr_title": "Fixed #23538 -- Added SchemaEditor for MySQL GIS.",
        "pr_body": "",
        "issue_closed_at": "2014-09-25T12:53:52",
        "base_commit": "215aa4f53b6bbd07d5c1eecfa94e7fcd00da813e"
      },
      "summary": "### Summary:\nThis issue is related to a deficiency in the Django framework's GIS (Geographic Information Systems) backend when using the MySQL database engine. Specifically, the problem stems from the absence of a SchemaEditor component, which is crucial for managing database schemas effectively during migrations. This deficiency leads to the omission of necessary indexes for GIS fields, potentially affecting applications that rely on these indexes for spatial queries.\n\nKey symptoms include the failure to create indexes for GIS fields during database migrations, which may result in reduced query performance and potentially incorrect query results for applications utilizing spatial data. The affected components primarily involve the MySQL GIS backend within Django, particularly the parts responsible for database introspections and schema management.\n\nThe potential impact is significant for applications relying on GIS features, as missing indexes can degrade performance and hinder the application's ability to execute spatial queries efficiently. This could be especially critical in applications with large datasets or those requiring precise spatial operations.\n\nRelevant technical details include modifications to several files within the Django framework's GIS and MySQL backends. These changes involve adjustments to the initialization of the DatabaseWrapper, introspection functions for both MySQL and SpatiaLite, and the handling of database indexes. These updates ensure that indexes for GIS fields are correctly created during schema migrations, thereby restoring expected functionality and performance.",
      "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: MySQL GIS backend missing SchemaEditor\n\nBody:\nI think this results in a missing index for GIS fields on apps that have migrations.\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/gis/db/backends/mysql/base.py\n  line: line 6\n  function: DatabaseWrapper.__init__\n\ndjango/contrib/gis/db/backends/mysql/introspection.py\n  function: MySQLIntrospection.get_geometry_type\n\ndjango/contrib/gis/db/backends/spatialite/introspection.py\n  function: SpatiaLiteIntrospection.get_geometry_type\n\ndjango/db/backends/mysql/introspection.py\n  function: DatabaseIntrospection.get_indexes\n"
    },
    {
      "similar_issue": {
        "issue_title": "Empty string related name should be invalid",
        "issue_body": "The actual model field check is\n​\nskipped\nif the\nrelated_name\nis an empty string when a warning should be raised since it's an invalid Python identifier.",
        "issue_id": 25560,
        "pr_number": 5437,
        "pr_title": "Fixed #25560 -- Made empty string related name invalid.",
        "pr_body": "Thanks to Ali Lotfi for the initial report and patch.\n",
        "issue_closed_at": "2015-10-16T13:18:21",
        "base_commit": "4dcc2a195595f8d7ddad45bc4baf98ffdeec7f41"
      },
      "summary": "### Summary: This issue pertains to the validation of model field attributes within a software system that utilizes object-relational mapping (ORM). Specifically, the problem arises when the `related_name` attribute of a model field is set to an empty string, which is not a valid Python identifier. The system currently bypasses the necessary model field checks under this condition, failing to raise a warning or error as expected. This oversight could lead to inconsistencies or errors during database operations that rely on these identifiers.\n\n1. **Problem description in general terms:** The system fails to validate certain attributes of model fields, particularly when these attributes are set to values that are not permissible as identifiers, such as an empty string. This results in the absence of warnings or errors that should be triggered to notify developers of the invalid input.\n\n2. **Key symptoms and behaviors observed:** The primary symptom is the absence of warnings during the model field validation process when an empty string is used as a `related_name`. This could potentially lead to silent failures or unexpected behavior in applications that depend on correctly configured model relationships.\n\n3. **Affected components or systems:** The issue affects components of the ORM system, specifically within the Django framework. It involves the model fields related to object relationships, as seen in the files `django/db/models/fields/related.py` and `django/db/models/fields/reverse_related.py`.\n\n4. **Potential impact or severity:** The impact of this issue could range from minor to significant, depending on the usage of the `related_name` attribute within applications. If unnoticed, it could lead to runtime errors or logical errors in database queries, which may affect data integrity and application functionality.\n\n5. **Any relevant technical details abstracted for broader understanding:** The patch addresses the issue by adding checks in the functions `RelatedField._check_related_name_is_valid` and `ForeignObjectRel.get_db_prep_lookup` to ensure that invalid identifiers, such as empty strings, trigger appropriate warnings or errors during model field validation. This change ensures that developers receive timely feedback on configuration issues, thereby preventing potential problems in data handling operations.",
      "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: Empty string related name should be invalid\n\nBody:\nThe actual model field check is\n​\nskipped\nif the\nrelated_name\nis an empty string when a warning should be raised since it's an invalid Python identifier.\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/db/models/fields/related.py\n  function: RelatedField._check_related_name_is_valid\n\ndjango/db/models/fields/reverse_related.py\n  function: ForeignObjectRel.get_db_prep_lookup\n"
    },
    {
      "similar_issue": {
        "issue_title": "Saving a FileField raises SuspiciousFileOperation in some scenarios.",
        "issue_body": "I came across this issue today when I was updating Django from 3.2.0 -> 3.2.1.\nIt's directly caused by:\n​\nhttps://docs.djangoproject.com/en/3.2/releases/3.2.1/#cve-2021-31542-potential-directory-traversal-via-uploaded-files\nStarting from 3.2.1, Django requires that only the basename is passed to\nFieldFile.save\nmethod, because otherwise it raises a new exception:\nSuspiciousFileOperation: File name ... includes path elements\nThe issue is that in\nFileField.pre_save\n, a full path is passed to\nFieldFile.save\n, causing the exception to be raised.\nCorrect me if I'm wrong, but file-like objects always contain the full path to the file in the\nname\nattribute (the built-in Django\nFile\nclass even uses it to reopen the file if it was closed), and so it seems to be a bug in Django itself.\nSteps to reproduce:\nmodel_instance.file_attribute = File(open(path, 'rb'))\nmodel_instance.save()\nI also created a PR with the fix:\n​\nhttps://github.com/django/django/pull/14354",
        "issue_id": 32718,
        "pr_number": 14372,
        "pr_title": "Fixed #32718 -- Relaxed file name validation in FileField.",
        "pr_body": "See [comment](https://code.djangoproject.com/ticket/32718#comment:26), ticket-32718.\r\n\r\n- ~~If `filename` passed to the `FileField.generate_filename()` is an absolute path, it will be converted to the `os.path.basename(filename)`.~~\r\n- Validate `filename` returned by `FileField.upload_to()` not a `filename` passed to the `FileField.generate_filename()` (`upload_to()` may completely ignored passed `filename`).\r\n- Allow relative paths (without dot segments) in the generated file name.\r\n\r\nThanks Jakub Kleň for the report.\r\n\r\nRegression in 0b79eb36915d178aef5c6a7bbce71b1e76d376d3.\r\n\r\n- [x] Discuss support for absolute paths.\r\n- [x] Release notes.",
        "issue_closed_at": "2021-05-13T01:53:57",
        "base_commit": "b81c7562fc33f50166d5120138d6398dc42b13c3"
      },
      "summary": "### Summary:\nThis issue pertains to a file handling error introduced in Django version 3.2.1, where the system raises a `SuspiciousFileOperation` exception due to a change in how file paths are processed when saving files. This problem arose following a security update (CVE-2021-31542) intended to prevent directory traversal via uploaded files. The core issue is that Django's `FileField.pre_save` method incorrectly passes a full file path to `FieldFile.save`, which is now required to only accept base filenames. This misalignment results in an exception being thrown, disrupting normal file saving operations.\n\nKey symptoms include the raising of a `SuspiciousFileOperation` exception when attempting to save a file using a file field in Django, specifically when the full path is passed instead of just the file's basename. This behavior occurs despite file-like objects typically containing full paths in their `name` attributes, which are used by Django's `File` class for file operations.\n\nThe affected components are primarily within the Django framework, particularly the file handling mechanisms associated with `FileField` and its interaction with file paths. The patch addresses issues in `django/core/files/utils.py` and `django/db/models/fields/files.py`.\n\nThe potential impact of this issue is significant for applications relying on file uploads and management, as it can prevent files from being saved correctly, thus leading to operational disruptions. The severity is compounded by the fact that this behavior is inconsistent with previous Django versions, potentially affecting existing deployments and requiring codebase adjustments.\n\nFrom a technical perspective, the issue underscores the importance of ensuring compatibility and correct path handling in file operations, especially following security updates that alter expected behaviors.",
      "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: Saving a FileField raises SuspiciousFileOperation in some scenarios.\n\nBody:\nI came across this issue today when I was updating Django from 3.2.0 -> 3.2.1.\nIt's directly caused by:\n​\nhttps://docs.djangoproject.com/en/3.2/releases/3.2.1/#cve-2021-31542-potential-directory-traversal-via-uploaded-files\nStarting from 3.2.1, Django requires that only the basename is passed to\nFieldFile.save\nmethod, because otherwise it raises a new exception:\nSuspiciousFileOperation: File name ... includes path elements\nThe issue is that in\nFileField.pre_save\n, a full path is passed to\nFieldFile.save\n, causing the exception to be raised.\nCorrect me if I'm wrong, but file-like objects always contain the full path to the file in the\nname\nattribute (the built-in Django\nFile\nclass even uses it to reopen the file if it was closed), and so it seems to be a bug in Django itself.\nSteps to reproduce:\nmodel_instance.file_attribute = File(open(path, 'rb'))\nmodel_instance.save()\nI also created a PR with the fix:\n​\nhttps://github.com/django/django/pull/14354\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/core/files/utils.py\n  line: line 1\n\ndjango/db/models/fields/files.py\n  function: FileField.generate_filename\n"
    },
    {
      "similar_issue": {
        "issue_title": "Queryset raises NotSupportedError when RHS has filterable=False attribute.",
        "issue_body": "I'm migrating my app to django 3.0.7 and I hit a strange behavior using a model class with a field labeled\nfilterable\nclass\nProductMetaDataType\n(\nmodels\n.\nModel\n):\nlabel\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n255\n,\nunique\n=\nTrue\n,\nblank\n=\nFalse\n,\nnull\n=\nFalse\n)\nfilterable\n=\nmodels\n.\nBooleanField\n(\ndefault\n=\nFalse\n,\nverbose_name\n=\n_\n(\n\"filterable\"\n))\nclass\nMeta\n:\napp_label\n=\n\"adminpricing\"\nverbose_name\n=\n_\n(\n\"product meta data type\"\n)\nverbose_name_plural\n=\n_\n(\n\"product meta data types\"\n)\ndef\n__str__\n(\nself\n):\nreturn\nself\n.\nlabel\nclass\nProductMetaData\n(\nmodels\n.\nModel\n):\nid\n=\nmodels\n.\nBigAutoField\n(\nprimary_key\n=\nTrue\n)\nproduct\n=\nmodels\n.\nForeignKey\n(\nProduit\n,\nnull\n=\nFalse\n,\nblank\n=\nFalse\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\nvalue\n=\nmodels\n.\nTextField\n(\nnull\n=\nFalse\n,\nblank\n=\nFalse\n)\nmarketplace\n=\nmodels\n.\nForeignKey\n(\nPlateforme\n,\nnull\n=\nFalse\n,\nblank\n=\nFalse\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\ndate_created\n=\nmodels\n.\nDateTimeField\n(\nnull\n=\nTrue\n,\ndefault\n=\ntimezone\n.\nnow\n)\nmetadata_type\n=\nmodels\n.\nForeignKey\n(\nProductMetaDataType\n,\nnull\n=\nFalse\n,\nblank\n=\nFalse\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\nclass\nMeta\n:\napp_label\n=\n\"adminpricing\"\nverbose_name\n=\n_\n(\n\"product meta data\"\n)\nverbose_name_plural\n=\n_\n(\n\"product meta datas\"\n)\nError happened when filtering ProductMetaData with a metadata_type :\nProductMetaData\n.\nobjects\n.\nfilter\n(\nvalue\n=\n\"Dark Vador\"\n,\nmetadata_type\n=\nself\n.\nbrand_metadata\n)\nError traceback :\nTraceback\n(\nmost\nrecent\ncall\nlast\n):\nFile\n\"/backoffice/backoffice/adminpricing/tests/test_pw.py\"\n,\nline\n481\n,\nin\ntest_checkpolicywarning_by_fields\nfor\np\nin\nProductMetaData\n.\nobjects\n.\nfilter\n(\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/manager.py\"\n,\nline\n82\n,\nin\nmanager_method\nreturn\ngetattr\n(\nself\n.\nget_queryset\n(),\nname\n)(\n*\nargs\n,\n**\nkwargs\n)\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/query.py\"\n,\nline\n904\n,\nin\nfilter\nreturn\nself\n.\n_filter_or_exclude\n(\nFalse\n,\n*\nargs\n,\n**\nkwargs\n)\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/query.py\"\n,\nline\n923\n,\nin\n_filter_or_exclude\nclone\n.\nquery\n.\nadd_q\n(\nQ\n(\n*\nargs\n,\n**\nkwargs\n))\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/sql/query.py\"\n,\nline\n1351\n,\nin\nadd_q\nclause\n,\n_\n=\nself\n.\n_add_q\n(\nq_object\n,\nself\n.\nused_aliases\n)\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/sql/query.py\"\n,\nline\n1378\n,\nin\n_add_q\nchild_clause\n,\nneeded_inner\n=\nself\n.\nbuild_filter\n(\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/sql/query.py\"\n,\nline\n1264\n,\nin\nbuild_filter\nself\n.\ncheck_filterable\n(\nvalue\n)\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/sql/query.py\"\n,\nline\n1131\n,\nin\ncheck_filterable\nraise\nNotSupportedError\n(\ndjango\n.\ndb\n.\nutils\n.\nNotSupportedError\n:\nProductMetaDataType\nis\ndisallowed\nin\nthe\nfilter\nclause\n.\nI changed label to\nfilterable_test\nand it fixed this issue\nThis should be documented or fix.",
        "issue_id": 31664,
        "pr_number": 13028,
        "pr_title": "Fixed #31664 -- Reallowed using non-expressions having filterable attribute as rhs in queryset filters.",
        "pr_body": "Check if rhs is an expression to be able to use `filterable` as model field name",
        "issue_closed_at": "2020-06-08T02:18:34",
        "base_commit": "78ad4b4b0201003792bfdbf1a7781cbc9ee03539"
      },
      "summary": "### Summary: \nThis issue arises when migrating a Django application to version 3.0.7. It involves a `NotSupportedError` being raised during a query operation on a model `ProductMetaData` that includes a BooleanField attribute named `filterable` in its related model `ProductMetaDataType`. The problem is specifically triggered when attempting to filter `ProductMetaData` objects based on a related `metadata_type` field, which references `ProductMetaDataType`.\n\n1. **Problem Description in General Terms:**\n   The issue pertains to an error encountered when executing a query with a filter condition involving a related model field that is marked with attributes not supported in the filter clause. The error is linked to the Django ORM's processing of such attributes and its internal checks on filterable fields.\n\n2. **Key Symptoms and Behaviors Observed:**\n   - A `NotSupportedError` is thrown when applying a filter on a query using a field from a related model that has a `filterable=False` attribute.\n   - The error message indicates that the `ProductMetaDataType` is disallowed in the filter clause.\n\n3. **Affected Components or Systems:**\n   - The Django ORM's query processing logic, specifically in how it handles field attributes during query filtering.\n   - The `ProductMetaData` and `ProductMetaDataType` models within the application's domain.\n\n4. **Potential Impact or Severity:**\n   - The error prevents certain query operations from completing successfully, potentially blocking critical data retrieval processes.\n   - This could impact functionalities reliant on such queries, leading to application failures or incorrect data handling.\n\n5. **Relevant Technical Details Abstracted for Broader Understanding:**\n   - The issue is tied to the Django ORM's internal filtering mechanisms, where specific field attributes (e.g., `filterable=False`) may not be adequately managed or documented in relation to query filters.\n   - The problem was resolved by altering the field label, indicating a possible oversight in the ORM's filterable check logic that should be documented or fixed to prevent similar issues in the future.\n\nChanges Summary:\n- The issue was addressed by modifying the label `filterable` to `filterable_test`, thus bypassing the error.\n- Affected code includes the function `Query.check_related_objects` in `django/db/models/sql/query.py`, indicating a potential area for further investigation or patching in the Django ORM.",
      "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: Queryset raises NotSupportedError when RHS has filterable=False attribute.\n\nBody:\nI'm migrating my app to django 3.0.7 and I hit a strange behavior using a model class with a field labeled\nfilterable\nclass\nProductMetaDataType\n(\nmodels\n.\nModel\n):\nlabel\n=\nmodels\n.\nCharField\n(\nmax_length\n=\n255\n,\nunique\n=\nTrue\n,\nblank\n=\nFalse\n,\nnull\n=\nFalse\n)\nfilterable\n=\nmodels\n.\nBooleanField\n(\ndefault\n=\nFalse\n,\nverbose_name\n=\n_\n(\n\"filterable\"\n))\nclass\nMeta\n:\napp_label\n=\n\"adminpricing\"\nverbose_name\n=\n_\n(\n\"product meta data type\"\n)\nverbose_name_plural\n=\n_\n(\n\"product meta data types\"\n)\ndef\n__str__\n(\nself\n):\nreturn\nself\n.\nlabel\nclass\nProductMetaData\n(\nmodels\n.\nModel\n):\nid\n=\nmodels\n.\nBigAutoField\n(\nprimary_key\n=\nTrue\n)\nproduct\n=\nmodels\n.\nForeignKey\n(\nProduit\n,\nnull\n=\nFalse\n,\nblank\n=\nFalse\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\nvalue\n=\nmodels\n.\nTextField\n(\nnull\n=\nFalse\n,\nblank\n=\nFalse\n)\nmarketplace\n=\nmodels\n.\nForeignKey\n(\nPlateforme\n,\nnull\n=\nFalse\n,\nblank\n=\nFalse\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\ndate_created\n=\nmodels\n.\nDateTimeField\n(\nnull\n=\nTrue\n,\ndefault\n=\ntimezone\n.\nnow\n)\nmetadata_type\n=\nmodels\n.\nForeignKey\n(\nProductMetaDataType\n,\nnull\n=\nFalse\n,\nblank\n=\nFalse\n,\non_delete\n=\nmodels\n.\nCASCADE\n)\nclass\nMeta\n:\napp_label\n=\n\"adminpricing\"\nverbose_name\n=\n_\n(\n\"product meta data\"\n)\nverbose_name_plural\n=\n_\n(\n\"product meta datas\"\n)\nError happened when filtering ProductMetaData with a metadata_type :\nProductMetaData\n.\nobjects\n.\nfilter\n(\nvalue\n=\n\"Dark Vador\"\n,\nmetadata_type\n=\nself\n.\nbrand_metadata\n)\nError traceback :\nTraceback\n(\nmost\nrecent\ncall\nlast\n):\nFile\n\"/backoffice/backoffice/adminpricing/tests/test_pw.py\"\n,\nline\n481\n,\nin\ntest_checkpolicywarning_by_fields\nfor\np\nin\nProductMetaData\n.\nobjects\n.\nfilter\n(\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/manager.py\"\n,\nline\n82\n,\nin\nmanager_method\nreturn\ngetattr\n(\nself\n.\nget_queryset\n(),\nname\n)(\n*\nargs\n,\n**\nkwargs\n)\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/query.py\"\n,\nline\n904\n,\nin\nfilter\nreturn\nself\n.\n_filter_or_exclude\n(\nFalse\n,\n*\nargs\n,\n**\nkwargs\n)\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/query.py\"\n,\nline\n923\n,\nin\n_filter_or_exclude\nclone\n.\nquery\n.\nadd_q\n(\nQ\n(\n*\nargs\n,\n**\nkwargs\n))\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/sql/query.py\"\n,\nline\n1351\n,\nin\nadd_q\nclause\n,\n_\n=\nself\n.\n_add_q\n(\nq_object\n,\nself\n.\nused_aliases\n)\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/sql/query.py\"\n,\nline\n1378\n,\nin\n_add_q\nchild_clause\n,\nneeded_inner\n=\nself\n.\nbuild_filter\n(\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/sql/query.py\"\n,\nline\n1264\n,\nin\nbuild_filter\nself\n.\ncheck_filterable\n(\nvalue\n)\nFile\n\"/usr/local/lib/python3.8/site-packages/django/db/models/sql/query.py\"\n,\nline\n1131\n,\nin\ncheck_filterable\nraise\nNotSupportedError\n(\ndjango\n.\ndb\n.\nutils\n.\nNotSupportedError\n:\nProductMetaDataType\nis\ndisallowed\nin\nthe\nfilter\nclause\n.\nI changed label to\nfilterable_test\nand it fixed this issue\nThis should be documented or fix.\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/db/models/sql/query.py\n  function: Query.check_related_objects\n"
    }
  ]
}