I'm working with two dev servers on my local machine (node & django's).
I've added django-cors-headers
to the project to allow all origins & methods (on dev) with the following settings :
CORS_ORIGIN_ALLOW_ALL = 'ALL'
CORS_ALLOW_METHODS = (
'GET',
'POST',
'PUT',
'PATCH',
'DELETE',
'OPTIONS'
)
I'm getting 405 when attempting DELETE. Looking at the response headers
HTTP/1.0 405 METHOD NOT ALLOWED
Date: Mon, 03 Nov 2014 10:04:43 GMT
Server: WSGIServer/0.1 Python/2.7.5
Vary: Cookie
X-Frame-Options: SAMEORIGIN
Content-Type: application/json
Access-Control-Allow-Origin: *
Allow: GET, POST, HEAD, OPTIONS
Notice that DELETE
& PATCH
/ PUT
are not present in the allowed methods list.
Is there something missing from my configuration ?
The response looks very similar to that of the list view (/api/resource/
) for a ViewSet. List views only support GET
, to list all of the objects, and POST
to create a new object.
DELETE
requests are only allowed on the detail view (/api/resource/1/
). This is because Django REST Framework needs to know what object you are looking to delete, and this information cannot be retrieved from just the list view.