aboutsummaryrefslogtreecommitdiffstats
path: root/src/rest/resource.py
diff options
context:
space:
mode:
authorTom Christie2010-12-31 16:21:20 +0000
committerTom Christie2010-12-31 16:21:20 +0000
commit48c7171aa05cd69ab8d9cd6f3a8eed52f18792a4 (patch)
tree9ab8b8883dbbe1301e8f0adbe10b0438fcee3da5 /src/rest/resource.py
parentc10a95de0869348ccf0f54d4f44f5b52b98e58f0 (diff)
downloaddjango-rest-framework-48c7171aa05cd69ab8d9cd6f3a8eed52f18792a4.tar.bz2
XML Parsers
Diffstat (limited to 'src/rest/resource.py')
-rw-r--r--src/rest/resource.py25
1 files changed, 18 insertions, 7 deletions
diff --git a/src/rest/resource.py b/src/rest/resource.py
index e6b41e07..4d8dd542 100644
--- a/src/rest/resource.py
+++ b/src/rest/resource.py
@@ -1,11 +1,15 @@
from django.http import HttpResponse
from django.core.urlresolvers import reverse
-from django.core.handlers.wsgi import STATUS_CODE_TEXT
from rest import emitters, parsers, utils
from decimal import Decimal
-for (key, val) in STATUS_CODE_TEXT.items():
- locals()["STATUS_%d_%s" % (key, val.replace(' ', '_'))] = key
+#
+STATUS_400_BAD_REQUEST = 400
+STATUS_405_METHOD_NOT_ALLOWED = 405
+STATUS_406_NOT_ACCEPTABLE = 406
+STATUS_415_UNSUPPORTED_MEDIA_TYPE = 415
+STATUS_500_INTERNAL_SERVER_ERROR = 500
+STATUS_501_NOT_IMPLEMENTED = 501
class ResourceException(Exception):
@@ -30,7 +34,8 @@ class Resource(object):
parsers = { 'application/json': parsers.JSONParser,
'application/xml': parsers.XMLParser,
- 'application/x-www-form-urlencoded': parsers.FormParser }
+ 'application/x-www-form-urlencoded': parsers.FormParser,
+ 'multipart/form-data': parsers.FormParser }
create_form = None
update_form = None
@@ -74,11 +79,17 @@ class Resource(object):
def _determine_parser(self, request):
"""Return the appropriate parser for the input, given the client's 'Content-Type' header,
and the content types that this Resource knows how to parse."""
+ content_type = request.META.get('CONTENT_TYPE', 'application/x-www-form-urlencoded')
+ split = content_type.split(';', 1)
+ if len(split) > 1:
+ content_type = split[0]
+ content_type = content_type.strip()
+
try:
- return self.parsers[request.META['CONTENT_TYPE']]
- except:
+ return self.parsers[content_type]
+ except KeyError:
raise ResourceException(STATUS_415_UNSUPPORTED_MEDIA_TYPE,
- {'detail': 'Unsupported media type'})
+ {'detail': 'Unsupported content type \'%s\'' % content_type})
def _determine_emitter(self, request):
"""Return the appropriate emitter for the output, given the client's 'Accept' header,