|
| 1 | +from rest_framework.decorators import api_view |
| 2 | +from rest_framework.response import Response |
| 3 | + |
| 4 | +@api_view() |
| 5 | +def normal_response(request): # $ requestHandler |
| 6 | + # has no pre-defined content type, since that will be negotiated |
| 7 | + # see https://www.django-rest-framework.org/api-guide/responses/ |
| 8 | + data = "data" |
| 9 | + resp = Response(data) # $ HttpResponse responseBody=data |
| 10 | + return resp |
| 11 | + |
| 12 | +@api_view() |
| 13 | +def plain_text_response(request): # $ requestHandler |
| 14 | + # this response is not the standard way to use the Djagno REST framework, but it |
| 15 | + # certainly is possible -- notice that the response contains double quotes |
| 16 | + data = 'this response will contain double quotes since it was a string' |
| 17 | + resp = Response(data, None, None, None, None, "text/plain") # $ HttpResponse mimetype=text/plain responseBody=data |
| 18 | + resp = Response(data=data, content_type="text/plain") # $ HttpResponse mimetype=text/plain responseBody=data |
| 19 | + return resp |
| 20 | + |
| 21 | +################################################################################ |
| 22 | +# Cookies |
| 23 | +################################################################################ |
| 24 | + |
| 25 | +@api_view |
| 26 | +def setting_cookie(request): |
| 27 | + resp = Response() # $ HttpResponse |
| 28 | + resp.set_cookie("key", "value") # $ CookieWrite CookieName="key" CookieValue="value" |
| 29 | + resp.set_cookie(key="key4", value="value") # $ CookieWrite CookieName="key4" CookieValue="value" |
| 30 | + resp.headers["Set-Cookie"] = "key2=value2" # $ MISSING: CookieWrite CookieRawHeader="key2=value2" |
| 31 | + resp.cookies["key3"] = "value3" # $ CookieWrite CookieName="key3" CookieValue="value3" |
| 32 | + resp.delete_cookie("key4") # $ CookieWrite CookieName="key4" |
| 33 | + resp.delete_cookie(key="key4") # $ CookieWrite CookieName="key4" |
| 34 | + return resp |
0 commit comments