{
  "id": "django__django-11095",
  "question": "add ModelAdmin.get_inlines() hook to allow set inlines based on the request or model instance.\nDescription\n\t\nadd ModelAdmin.get_inlines() hook to allow set inlines based on the request or model instance.\nCurrently, We can override the method get_inline_instances to do such a thing, but a for loop should be copied to my code. So I wished add a hook get_inlines(request, obj=None)\n",
  "answer": "{\"task_id\": \"f0962e3c-65f1-42e3-a48c-629ff395781f\", \"workflow_run_id\": \"ac71509b-0a7c-4836-9885-fa01b843f242\", \"data\": {\"id\": \"ac71509b-0a7c-4836-9885-fa01b843f242\", \"workflow_id\": \"9a0a6efa-4d15-4876-b13f-4fb6a999caa2\", \"status\": \"succeeded\", \"outputs\": {\"final_patch\": [\"--- a/django/contrib/admin/options.py\\n+++ b/django/contrib/admin/options.py\\n@@ -1075,6 +1075,15 @@ class ModelAdmin(BaseModelAdmin):\\n         return formset\\n \\n     def get_inline_instances(self, request, obj=None):\\n+        \\\"\\\"\\\"\\n+        Return a list of inline instances for the given request and object.\\n+        \\\"\\\"\\\"\\n+        inline_instances = []\\n+        for inline_class in self.get_inlines(request, obj):\\n+            inline = inline_class(self.model, self.admin_site)\\n+            if request:\\n+                if not (hasattr(inline, 'has_view_or_change_permission') and\\n+                        inline.has_view_or_change_permission(request, obj) or\\n+                        hasattr(inline, 'has_add_permission') and\\n+                        inline.has_add_permission(request, obj) or\\n+                        hasattr(inline, 'has_change_permission') and\\n+                        inline.has_change_permission(request, obj) or\\n+                        hasattr(inline, 'has_delete_permission') and\\n+                        inline.has_delete_permission(request, obj)):\\n+                    continue\\n+                if obj is None:\\n+                    if not inline.has_add_permission(request, obj):\\n+                        continue\\n+                else:\\n+                    if not (inline.has_view_permission(request, obj) or\\n+                            inline.has_change_permission(request, obj)):\\n+                        continue\\n+            inline_instances.append(inline)\\n+        return inline_instances\\n+\\n+    def get_inlines(self, request, obj=None):\\n+        \\\"\\\"\\\"\\n+        Hook for specifying custom inlines based on the request or object.\\n+        \\\"\\\"\\\"\\n+        return self.inlines\", \"--- a/django/contrib/admin/options.py\\n+++ b/django/contrib/admin/options.py\\n@@ -1075,6 +1075,12 @@ class ModelAdmin(BaseModelAdmin):\\n         return formset\\n \\n     def get_inline_instances(self, request, obj=None):\\n+        inline_instances = []\\n+        for inline_class in self.get_inlines(request, obj):\\n+            inline = inline_class(self.model, self.admin_site)\\n+            if request:\\n+                if not (inline.has_view_permission(request, obj) or\\n+                        inline.has_change_permission(request, obj) or\\n+                        inline.has_add_permission(request, obj) or\\n+                        inline.has_delete_permission(request, obj)):\\n+                    continue\\n+            inline_instances.append(inline)\\n+        return inline_instances\\n+\\n+    def get_inlines(self, request, obj=None):\\n+        \\\"\\\"\\\"\\n+        Hook for specifying custom inlines based on the request or object.\\n+        \\\"\\\"\\\"\\n+        return self.inlines\", \"--- a/django/contrib/admin/options.py\\n+++ b/django/contrib/admin/options.py\\n@@ -1077,7 +1077,7 @@ class ModelAdmin(BaseModelAdmin):\\n     def get_inline_instances(self, request, obj=None):\\n         inline_instances = []\\n-        for inline_class in self.inlines:\\n+        for inline_class in self.get_inlines(request, obj):\\n             inline = inline_class(self.model, self.admin_site)\\n             if request:\\n                 if not (inline.has_view_permission(request, obj) or\\n@@ -1087,6 +1087,12 @@ class ModelAdmin(BaseModelAdmin):\\n                     continue\\n             inline_instances.append(inline)\\n         return inline_instances\\n+\\n+    def get_inlines(self, request, obj=None):\\n+        \\\"\\\"\\\"\\n+        Hook for specifying custom inlines based on the request or object.\\n+        \\\"\\\"\\\"\\n+        return self.inlines\", \"--- a/django/contrib/admin/options.py\\n+++ b/django/contrib/admin/options.py\\n@@ -1077,7 +1077,7 @@ class ModelAdmin(BaseModelAdmin):\\n     def get_inline_instances(self, request, obj=None):\\n         inline_instances = []\\n-        for inline_class in self.inlines:\\n+        for inline_class in self.get_inlines(request, obj):\\n             inline = inline_class(self.model, self.admin_site)\\n             if request:\\n                 if not (inline.has_view_permission(request, obj) or\\n@@ -1087,6 +1087,17 @@ class ModelAdmin(BaseModelAdmin):\\n                     continue\\n             inline_instances.append(inline)\\n         return inline_instances\\n+\\n+    def get_inlines(self, request, obj=None):\\n+        \\\"\\\"\\\"\\n+        Hook for specifying custom inlines based on the request or object.\\n+        By default, returns the inlines attribute. Override this method to\\n+        customize inline behavior dynamically.\\n+        \\\"\\\"\\\"\\n+        # Cache key based on request user and object pk for performance\\n+        if hasattr(self, '_cached_inlines'):\\n+            return self._cached_inlines\\n+        return self.inlines\", \"--- a/django/contrib/admin/options.py\\n+++ b/django/contrib/admin/options.py\\n@@ -1077,7 +1077,7 @@ class ModelAdmin(BaseModelAdmin):\\n     def get_inline_instances(self, request, obj=None):\\n         inline_instances = []\\n-        for inline_class in self.inlines:\\n+        for inline_class in self.get_inlines(request, obj):\\n             inline = inline_class(self.model, self.admin_site)\\n             if request:\\n                 if not (inline.has_view_permission(request, obj) or\\n@@ -1087,6 +1087,14 @@ class ModelAdmin(BaseModelAdmin):\\n                     continue\\n             inline_instances.append(inline)\\n         return inline_instances\\n+\\n+    def get_inlines(self, request, obj=None):\\n+        \\\"\\\"\\\"\\n+        Hook for specifying custom inlines based on the request or object.\\n+        Override this method to customize which inlines are displayed\\n+        based on the current request or the object being edited.\\n+        \\\"\\\"\\\"\\n+        return self.inlines\", \"diff\\n--- a/django/contrib/admin/options.py\\n+++ b/django/contrib/admin/options.py\\n@@ -1077,7 +1077,7 @@ class ModelAdmin(BaseModelAdmin):\\n     def get_inline_instances(self, request, obj=None):\\n         inline_instances = []\\n-        for inline_class in self.inlines:\\n+        for inline_class in self.get_inlines(request, obj):\\n             inline = inline_class(self.model, self.admin_site)\\n             if request:\\n                 if not (inline.has_view_permission(request, obj) or\\n@@ -1087,6 +1087,14 @@ class ModelAdmin(BaseModelAdmin):\\n                     continue\\n             inline_instances.append(inline)\\n         return inline_instances\\n+\\n+    def get_inlines(self, request, obj=None):\\n+        \\\"\\\"\\\"\\n+        Hook for specifying custom inlines based on the request or object.\\n+        Override this method to customize which inlines are displayed\\n+        based on the current request or the object being edited.\\n+        \\\"\\\"\\\"\\n+        return self.inlines\\n\", \"diff\\n--- a/django/contrib/admin/options.py\\n+++ b/django/contrib/admin/options.py\\n@@ -1077,7 +1077,7 @@ class ModelAdmin(BaseModelAdmin):\\n     def get_inline_instances(self, request, obj=None):\\n         inline_instances = []\\n-        for inline_class in self.inlines:\\n+        for inline_class in self.get_inlines(request, obj):\\n             inline = inline_class(self.model, self.admin_site)\\n             if request:\\n                 if not (inline.has_view_permission(request, obj) or\\n@@ -1087,6 +1087,14 @@ class ModelAdmin(BaseModelAdmin):\\n                     continue\\n             inline_instances.append(inline)\\n         return inline_instances\\n+\\n+    def get_inlines(self, request, obj=None):\\n+        \\\"\\\"\\\"\\n+        Hook for specifying custom inlines based on the request or object.\\n+        Override this method to customize which inlines are displayed\\n+        based on the current request or the object being edited.\\n+        \\\"\\\"\\\"\\n+        return self.inlines\\n\", \"diff\\n--- a/django/contrib/admin/options.py\\n+++ b/django/contrib/admin/options.py\\n@@ -1077,7 +1077,7 @@ class ModelAdmin(BaseModelAdmin):\\n     def get_inline_instances(self, request, obj=None):\\n         inline_instances = []\\n-        for inline_class in self.inlines:\\n+        for inline_class in self.get_inlines(request, obj):\\n             inline = inline_class(self.model, self.admin_site)\\n             if request:\\n                 if not (inline.has_view_permission(request, obj) or\\n@@ -1087,6 +1087,14 @@ class ModelAdmin(BaseModelAdmin):\\n                     continue\\n             inline_instances.append(inline)\\n         return inline_instances\\n+\\n+    def get_inlines(self, request, obj=None):\\n+        \\\"\\\"\\\"\\n+        Hook for specifying custom inlines based on the request or object.\\n+        Override this method to customize which inlines are displayed\\n+        based on the current request or the object being edited.\\n+        \\\"\\\"\\\"\\n+        return self.inlines\\n\"]}, \"error\": \"\", \"elapsed_time\": 101.390881, \"total_tokens\": 39177, \"total_steps\": 30, \"created_at\": 1754647341, \"finished_at\": 1754647442}}"
}