From 30e22a21064a83f072ff2f735216f059186f88b4 Mon Sep 17 00:00:00 2001 From: Darren Maki Date: Fri, 16 Sep 2022 16:42:46 -0400 Subject: [PATCH] Fix performance of EmailAdmin view. Add a `filter` and `select_related` to the queryset to limit the records being fetched by the custom `get_queryset` logic. Fixes #415 --- post_office/admin.py | 12 +++++++++++- 1 file changed, 11 insertions(+), 1 deletion(-) diff --git a/post_office/admin.py b/post_office/admin.py index 71e967ab..00ba5e87 100644 --- a/post_office/admin.py +++ b/post_office/admin.py @@ -40,9 +40,19 @@ def get_queryset(self, request): are displayed anyway. """ queryset = super().get_queryset(request) + + # The queryset does not have the Email FK filter applied at this point. + # That happens later when the inline formset is created as part of the + # admin view. Here we explicitly add the Email filter to avoid selecting + # every row in the table during this special filtering step. + email = request.resolver_match.kwargs.get("object_id", None) + if email is None: + return queryset + email_filter = queryset.filter(email=email).select_related("attachment") + inlined_attachments = [ a.id - for a in queryset + for a in email_filter if isinstance(a.attachment.headers, dict) and a.attachment.headers.get("Content-Disposition", "").startswith("inline") ]