mirror of
https://github.com/encode/django-rest-framework.git
synced 2025-06-07 15:13:15 +03:00
Fix YAML parser bug
This commit is contained in:
parent
ca9465f11e
commit
9277f438cb
|
@ -92,28 +92,25 @@ class JSONParser(BaseParser):
|
||||||
{'detail': 'JSON parse error - %s' % unicode(exc)})
|
{'detail': 'JSON parse error - %s' % unicode(exc)})
|
||||||
|
|
||||||
|
|
||||||
if yaml:
|
class YAMLParser(BaseParser):
|
||||||
class YAMLParser(BaseParser):
|
"""
|
||||||
|
Parses YAML-serialized data.
|
||||||
|
"""
|
||||||
|
|
||||||
|
media_type = 'application/yaml'
|
||||||
|
|
||||||
|
def parse(self, stream):
|
||||||
"""
|
"""
|
||||||
Parses YAML-serialized data.
|
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:
|
||||||
media_type = 'application/yaml'
|
return (yaml.safe_load(stream), None)
|
||||||
|
except (ValueError, yaml.parser.ParserError), exc:
|
||||||
def parse(self, stream):
|
content = {'detail': 'YAML parse error - %s' % unicode(exc)}
|
||||||
"""
|
raise ErrorResponse(status.HTTP_400_BAD_REQUEST, content)
|
||||||
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)})
|
|
||||||
else:
|
|
||||||
YAMLParser = None
|
|
||||||
|
|
||||||
|
|
||||||
class PlainTextParser(BaseParser):
|
class PlainTextParser(BaseParser):
|
||||||
|
@ -248,5 +245,8 @@ DEFAULT_PARSERS = (
|
||||||
XMLParser
|
XMLParser
|
||||||
)
|
)
|
||||||
|
|
||||||
if YAMLParser:
|
if yaml:
|
||||||
DEFAULT_PARSERS += (YAMLParser,)
|
DEFAULT_PARSERS += (YAMLParser, )
|
||||||
|
else:
|
||||||
|
YAMLParser = None
|
||||||
|
|
||||||
|
|
|
@ -152,25 +152,22 @@ class XMLRenderer(BaseRenderer):
|
||||||
return dict2xml(obj)
|
return dict2xml(obj)
|
||||||
|
|
||||||
|
|
||||||
if yaml:
|
class YAMLRenderer(BaseRenderer):
|
||||||
class YAMLRenderer(BaseRenderer):
|
"""
|
||||||
|
Renderer which serializes to YAML.
|
||||||
|
"""
|
||||||
|
|
||||||
|
media_type = 'application/yaml'
|
||||||
|
format = 'yaml'
|
||||||
|
|
||||||
|
def render(self, obj=None, media_type=None):
|
||||||
"""
|
"""
|
||||||
Renderer which serializes to YAML.
|
Renders *obj* into serialized YAML.
|
||||||
"""
|
"""
|
||||||
|
if obj is None:
|
||||||
|
return ''
|
||||||
|
|
||||||
media_type = 'application/yaml'
|
return yaml.safe_dump(obj)
|
||||||
format = 'yaml'
|
|
||||||
|
|
||||||
def render(self, obj=None, media_type=None):
|
|
||||||
"""
|
|
||||||
Renders *obj* into serialized YAML.
|
|
||||||
"""
|
|
||||||
if obj is None:
|
|
||||||
return ''
|
|
||||||
|
|
||||||
return yaml.safe_dump(obj)
|
|
||||||
else:
|
|
||||||
YAMLRenderer = None
|
|
||||||
|
|
||||||
|
|
||||||
class TemplateRenderer(BaseRenderer):
|
class TemplateRenderer(BaseRenderer):
|
||||||
|
@ -409,5 +406,7 @@ DEFAULT_RENDERERS = (
|
||||||
XMLRenderer
|
XMLRenderer
|
||||||
)
|
)
|
||||||
|
|
||||||
if YAMLRenderer:
|
if yaml:
|
||||||
DEFAULT_RENDERERS += (YAMLRenderer,)
|
DEFAULT_RENDERERS += (YAMLRenderer, )
|
||||||
|
else:
|
||||||
|
YAMLRenderer = None
|
||||||
|
|
Loading…
Reference in New Issue
Block a user