{
  "id": "django__django-11433",
  "question": "Allow `cleaned_data` to overwrite fields' default values.\nDescription\n\t\nSee comments here: ​https://github.com/django/django/pull/7068/files#r289432409\nCurrently, when submitting a form, if 'some_field' isn't in the data payload (e.g. it wasn't included in the form, perhaps because its value is derived from another field), and 'some_field' has a default value on the model, it cannot be overwritten with 'self.cleaned_data'.\nThis does not really follow the paradigm of modifying data in 'cleaned_data'. It requires the user to copy and overwrite the raw data submitted with the form.\n",
  "answer": "{\"task_id\": \"8921c760-b785-46fb-a93d-8e5e47422ae2\", \"workflow_run_id\": \"c48ed69a-e332-44d5-9b92-1a009a0eab6f\", \"data\": {\"id\": \"c48ed69a-e332-44d5-9b92-1a009a0eab6f\", \"workflow_id\": \"9a0a6efa-4d15-4876-b13f-4fb6a999caa2\", \"status\": \"succeeded\", \"outputs\": {\"final_patch\": [\"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -451,10 +451,12 @@ class BaseModelForm(BaseForm):\\n         if self.instance.pk is None:\\n             fail_message = 'created'\\n         else:\\n             fail_message = 'changed'\\n-        return save_instance(self, self.instance, self._meta.fields,\\n-                             fail_message, commit, self._meta.exclude,\\n-                             construct=False)\\n+        # Apply all cleaned_data values to the instance, not just form fields\\n+        for field_name, value in self.cleaned_data.items():\\n+            setattr(self.instance, field_name, value)\\n+        return save_instance(self, self.instance, None,\\n+                             fail_message, commit, None,\\n+                             construct=False)\", \"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -451,10 +451,16 @@ class BaseModelForm(BaseForm):\\n         if self.instance.pk is None:\\n             fail_message = 'created'\\n         else:\\n             fail_message = 'changed'\\n+        \\n+        # Include all fields from cleaned_data, not just form fields\\n+        fields_to_save = set(self._meta.fields or [])\\n+        fields_to_save.update(self.cleaned_data.keys())\\n+        fields_to_save = list(fields_to_save)\\n+        \\n         return save_instance(self, self.instance, self._meta.fields,\\n                              fail_message, commit, self._meta.exclude,\\n-                             construct=False)\\n+                             construct=False, cleaned_data=self.cleaned_data)\", \"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -451,6 +451,12 @@ class BaseModelForm(BaseForm):\\n         if self.instance.pk is None:\\n             fail_message = 'created'\\n         else:\\n             fail_message = 'changed'\\n+        \\n+        # Apply all cleaned_data to instance, including fields not in form\\n+        for field_name, value in self.cleaned_data.items():\\n+            if hasattr(self.instance, field_name):\\n+                setattr(self.instance, field_name, value)\\n+        \\n         return save_instance(self, self.instance, self._meta.fields,\\n                              fail_message, commit, self._meta.exclude,\\n                              construct=False)\", \"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -451,8 +451,13 @@ class BaseModelForm(BaseForm):\\n         if self.instance.pk is None:\\n             fail_message = 'created'\\n         else:\\n             fail_message = 'changed'\\n-        return save_instance(self, self.instance, self._meta.fields,\\n+        \\n+        # Ensure all cleaned_data fields are included in save operation\\n+        all_fields = list(self._meta.fields or [])\\n+        all_fields.extend([f for f in self.cleaned_data.keys() if f not in all_fields])\\n+        \\n+        return save_instance(self, self.instance, all_fields,\\n                              fail_message, commit, self._meta.exclude,\\n                              construct=False)\", \"--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -451,6 +451,12 @@ class BaseModelForm(BaseForm):\\n         if self.instance.pk is None:\\n             fail_message = 'created'\\n         else:\\n             fail_message = 'changed'\\n+        \\n+        # Apply all cleaned_data values to instance, overriding defaults\\n+        for field_name, value in self.cleaned_data.items():\\n+            if hasattr(self.instance, field_name):\\n+                setattr(self.instance, field_name, value)\\n+        \\n         return save_instance(self, self.instance, self._meta.fields,\\n                              fail_message, commit, self._meta.exclude,\\n                              construct=False)\\n@@ -472,6 +478,11 @@ class BaseModelForm(BaseForm):\\n         Saves the many-to-many fields for the form.\\n         \\\"\\\"\\\"\\n         if self.cleaned_data:\\n+            # Handle m2m fields from cleaned_data that may not be in form fields\\n+            for field_name, value in self.cleaned_data.items():\\n+                if field_name not in self.fields and hasattr(self.instance, field_name):\\n+                    field = self.instance._meta.get_field(field_name)\\n+                    if field.many_to_many:\\n+                        getattr(self.instance, field_name).set(value)\\n             for f in self._meta.fields:\\n                 if not hasattr(f, 'save_form_data'):\\n                     continue\", \"diff\\n--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -451,6 +451,12 @@ class BaseModelForm(BaseForm):\\n         if self.instance.pk is None:\\n             fail_message = 'created'\\n         else:\\n             fail_message = 'changed'\\n+        \\n+        # Apply all cleaned_data values to instance, including fields not in form\\n+        for field_name, value in self.cleaned_data.items():\\n+            if hasattr(self.instance, field_name):\\n+                setattr(self.instance, field_name, value)\\n+        \\n         return save_instance(self, self.instance, self._meta.fields,\\n                              fail_message, commit, self._meta.exclude,\\n                              construct=False)\\n\", \"diff\\n--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -451,6 +451,12 @@ class BaseModelForm(BaseForm):\\n         if self.instance.pk is None:\\n             fail_message = 'created'\\n         else:\\n             fail_message = 'changed'\\n+        \\n+        # Apply all cleaned_data values to instance, including fields not in form\\n+        for field_name, value in self.cleaned_data.items():\\n+            if hasattr(self.instance, field_name):\\n+                setattr(self.instance, field_name, value)\\n+        \\n         return save_instance(self, self.instance, self._meta.fields,\\n                              fail_message, commit, self._meta.exclude,\\n                              construct=False)\\n\", \"diff\\n--- a/django/forms/models.py\\n+++ b/django/forms/models.py\\n@@ -451,6 +451,12 @@ class BaseModelForm(BaseForm):\\n         if self.instance.pk is None:\\n             fail_message = 'created'\\n         else:\\n             fail_message = 'changed'\\n+        \\n+        # Apply all cleaned_data values to instance, including fields not in form\\n+        for field_name, value in self.cleaned_data.items():\\n+            if hasattr(self.instance, field_name):\\n+                setattr(self.instance, field_name, value)\\n+        \\n         return save_instance(self, self.instance, self._meta.fields,\\n                              fail_message, commit, self._meta.exclude,\\n                              construct=False)\\n\"]}, \"error\": \"\", \"elapsed_time\": 94.269806, \"total_tokens\": 35244, \"total_steps\": 30, \"created_at\": 1754649146, \"finished_at\": 1754649240}}"
}