From 2a5d2eefc751be012fdebd75d8177c42bf5a76fc Mon Sep 17 00:00:00 2001 From: Collin Anderson Date: Thu, 5 May 2022 15:23:54 -0400 Subject: [PATCH] Fixed #33683 -- Document HttpResponseBase and allow import from django.http --- django/http/__init__.py | 2 ++ docs/ref/request-response.txt | 12 ++++++++++++ 2 files changed, 14 insertions(+) diff --git a/django/http/__init__.py b/django/http/__init__.py index 4c997154d9..87109059a3 100644 --- a/django/http/__init__.py +++ b/django/http/__init__.py @@ -11,6 +11,7 @@ from django.http.response import ( Http404, HttpResponse, HttpResponseBadRequest, + HttpResponseBase, HttpResponseForbidden, HttpResponseGone, HttpResponseNotAllowed, @@ -31,6 +32,7 @@ __all__ = [ "RawPostDataException", "UnreadablePostError", "HttpResponse", + "HttpResponseBase", "StreamingHttpResponse", "HttpResponseRedirect", "HttpResponsePermanentRedirect", diff --git a/docs/ref/request-response.txt b/docs/ref/request-response.txt index 3a3c4d14fc..81558c8916 100644 --- a/docs/ref/request-response.txt +++ b/docs/ref/request-response.txt @@ -1150,6 +1150,9 @@ the data to the client. Because the content can't be accessed, many middleware can't function normally. For example the ``ETag`` and ``Content-Length`` headers can't be generated for streaming responses. +The :class:`HttpResponseBase` base class is common between +:class:`HttpResponse` and :class:`StreamingHttpResponse`. + Attributes ---------- @@ -1218,3 +1221,12 @@ Methods This method is automatically called during the response initialization and set various headers (``Content-Length``, ``Content-Type``, and ``Content-Disposition``) depending on ``open_file``. + +``HttpResponseBase`` class +========================== + +.. class:: HttpResponseBase + +The :class:`HttpResponseBase` class is common to all Django responses. +It should not be used to create responses directly, but it can be +useful for type-checking.