aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authormarkotibold2011-06-26 01:34:52 +0200
committermarkotibold2011-06-26 01:34:52 +0200
commit7f536c1db3950bff2486fd243748f833565c9155 (patch)
treeb92dda970166130d1009a6fe8d77dbf34b171fce
parent0b18b58c170aae0c2a93a608997e557fdcefe826 (diff)
downloaddjango-rest-framework-7f536c1db3950bff2486fd243748f833565c9155.tar.bz2
Very basic YAML support. Probably needs some tweaking, and definitely needs tests.
-rw-r--r--djangorestframework/parsers.py23
-rw-r--r--djangorestframework/renderers.py25
2 files changed, 43 insertions, 5 deletions
diff --git a/djangorestframework/parsers.py b/djangorestframework/parsers.py
index 3346a26e..a25ca89e 100644
--- a/djangorestframework/parsers.py
+++ b/djangorestframework/parsers.py
@@ -18,12 +18,15 @@ from djangorestframework import status
from djangorestframework.response import ErrorResponse
from djangorestframework.utils.mediatypes import media_type_matches
+import yaml
+
__all__ = (
'BaseParser',
'JSONParser',
'PlainTextParser',
'FormParser',
'MultiPartParser',
+ 'YAMLParser',
)
@@ -84,6 +87,26 @@ class JSONParser(BaseParser):
{'detail': 'JSON parse error - %s' % unicode(exc)})
+class YAMLParser(BaseParser):
+ """
+ Parses YAML-serialized data.
+ """
+
+ media_type = 'application/yaml'
+
+ def parse(self, stream):
+ """
+ Returns a 2-tuple of `(data, files)`.
+
+ `data` will be an object which is the parsed content of the response.
+ `files` will always be `None`.
+ """
+ try:
+ return (yaml.safe_load(stream), None)
+ except ValueError, exc:
+ raise ErrorResponse(status.HTTP_400_BAD_REQUEST,
+ {'detail': 'YAML parse error - %s' % unicode(exc)})
+
class PlainTextParser(BaseParser):
"""
diff --git a/djangorestframework/renderers.py b/djangorestframework/renderers.py
index 13cd52f5..18ffbf66 100644
--- a/djangorestframework/renderers.py
+++ b/djangorestframework/renderers.py
@@ -11,7 +11,7 @@ from django.core.serializers.json import DateTimeAwareJSONEncoder
from django.template import RequestContext, loader
from django.utils import simplejson as json
-from djangorestframework import status
+
from djangorestframework.compat import apply_markdown
from djangorestframework.utils import dict2xml, url_resolves
from djangorestframework.utils.breadcrumbs import get_breadcrumbs
@@ -19,10 +19,9 @@ from djangorestframework.utils.description import get_name, get_description
from djangorestframework.utils.mediatypes import get_media_type_params, add_media_type_param, media_type_matches
from djangorestframework import VERSION
-from decimal import Decimal
-import re
import string
from urllib import quote_plus
+import yaml
__all__ = (
'BaseRenderer',
@@ -31,7 +30,8 @@ __all__ = (
'DocumentingHTMLRenderer',
'DocumentingXHTMLRenderer',
'DocumentingPlainTextRenderer',
- 'XMLRenderer'
+ 'XMLRenderer',
+ 'YAMLRenderer'
)
@@ -120,6 +120,20 @@ class XMLRenderer(BaseRenderer):
return ''
return dict2xml(obj)
+class YAMLRenderer(BaseRenderer):
+ """
+ Renderer which serializes to YAML.
+ """
+
+ media_type = 'application/yaml'
+
+ def render(self, obj=None, media_type=None):
+ """
+ Renders *obj* into serialized YAML.
+ """
+ if obj is None:
+ return ''
+ return yaml.dump(obj)
class TemplateRenderer(BaseRenderer):
"""
@@ -346,6 +360,7 @@ DEFAULT_RENDERERS = ( JSONRenderer,
DocumentingHTMLRenderer,
DocumentingXHTMLRenderer,
DocumentingPlainTextRenderer,
- XMLRenderer )
+ XMLRenderer,
+ YAMLRenderer )