예제 #1
0
def xml_dumps(data):
    def to_xml(xml, data):
        if isinstance(data, (list, tuple)):
            for item in data:
                xml.startElement("resource", {})
                to_xml(xml, item)
                xml.endElement("resource")
        elif isinstance(data, dict):
            for key, value in data.iteritems():
                xml.startElement(key, {})
                to_xml(xml, value)
                xml.endElement(key)
        else:
            xml.characters(smart_text(data))

    stream = StringIO()

    xml = SimplerXMLGenerator(stream, "utf-8")
    xml.startDocument()
    xml.startElement("response", {})

    to_xml(xml, data)

    xml.endElement("response")
    xml.endDocument()

    return stream.getvalue()
예제 #2
0
    def render(self, data, *args, **kwargs):
        charset = 'utf-8'
        root_node = 'xforms'
        xmlns = "http://openrosa.org/xforms/xformsList"

        if 'detail' in data.keys():
            stream = StringIO()

            xml = SimplerXMLGenerator(stream, charset)
            xml.startDocument()
            xml.startElement(root_node, {'xmlns': xmlns})

            for key, value in six.iteritems(data):
                xml.startElement(key, {})
                xml.characters(smart_text(value))
                xml.endElement(key)

            xml.endElement(root_node)
            xml.endDocument()
            return stream.getvalue()
        else:
            json = self.transform_to_xform_json(data)
            survey = create_survey_element_from_dict(json)
            xml = survey.xml()
            fix_languages(xml)
            xml = xml.toxml()

            xml = self.insert_version_attribute(xml,
                                                data.get('id_string'),
                                                data.get('version'))
            xml = self.insert_uuid_bind(xml, data.get('id_string'))

            return xml
예제 #3
0
 def error(self, request, status_code, error_dict=None):
     """
     Return XML error response that includes a human readable error
     message, application-specific errors and a machine readable
     status code.
     """
     from django.conf import settings
     if not error_dict:
         error_dict = ErrorDict()
     response = HttpResponse(mimetype = self.mimetype)
     response.status_code = status_code
     xml = SimplerXMLGenerator(response, settings.DEFAULT_CHARSET)
     xml.startDocument()
     xml.startElement("django-error", {})
     xml.addQuickElement(name="error-message", contents='%d %s' % (status_code, STATUS_CODE_TEXT[status_code]))
     xml.addQuickElement(name="status-code", contents=str(status_code))
     if error_dict:
         xml.startElement("model-errors", {})
         for (model_field, errors) in error_dict.items():
             for error in errors:
                 xml.addQuickElement(name=model_field, contents=error)
         xml.endElement("model-errors")
     xml.endElement("django-error")
     xml.endDocument()
     return response
예제 #4
0
파일: renderers.py 프로젝트: kimetrica/kpi
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        Duplicate `rest_framework_xml.renderers.XMLRenderer.render()` to add
        the `xmlns` attribute to the root node
        """
        if not hasattr(self, 'xmlns'):
            raise NotImplemented('`xmlns` must be implemented!')

        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, self.charset)
        xml.startDocument()
        xml.startElement(
            self.root_tag_name,
            {'xmlns': f'http://openrosa.org/xforms/{self.xmlns}'},
        )

        self._to_xml(xml, data)

        xml.endElement(self.root_tag_name)
        xml.endDocument()
        return stream.getvalue()
예제 #5
0
class XMLGenerator(BaseGenerator):
    def __init__(self, pretty_print: bool = False):
        self.pretty_print = pretty_print
        self.renderer = XMLRenderer()
        self.stream = StringIO()
        self.xml = SimplerXMLGenerator(self.stream, XMLRenderer.charset)

    def start(self):
        self.xml.startDocument()
        self.xml.startElement(XMLRenderer.root_tag_name, {})

    def add_list_item(self, data: dict):
        self.xml.startElement(XMLRenderer.item_tag_name, {})
        self.renderer._to_xml(self.xml, data)
        self.xml.endElement(XMLRenderer.item_tag_name)

    def finish(self):
        self.xml.endElement(XMLRenderer.root_tag_name)
        self.xml.endDocument()

    def get_data(self):
        if not self.pretty_print:
            return self.stream.getvalue()
        else:
            tree = etree.XML(self.stream.getvalue().encode('utf-8'))
            string = etree.tostring(tree,
                                    encoding='utf-8',
                                    pretty_print=True,
                                    xml_declaration=True)
            return string.decode('utf-8')
예제 #6
0
 def error(self, request, status_code, error_dict=None):
     """
     Return XML error response that includes a human readable error
     message, application-specific errors and a machine readable
     status code.
     """
     from django.conf import settings
     if not error_dict:
         error_dict = ErrorDict()
     response = HttpResponse(mimetype = self.mimetype)
     response.status_code = status_code
     xml = SimplerXMLGenerator(response, settings.DEFAULT_CHARSET)
     xml.startDocument()
     xml.startElement("django-error", {})
     xml.addQuickElement(name="error-message", contents='%d %s' % (status_code, STATUS_CODE_TEXT[status_code]))
     xml.addQuickElement(name="status-code", contents=str(status_code))
     if error_dict:
         xml.startElement("model-errors", {})
         for (model_field, errors) in error_dict.items():
             for error in errors:
                 xml.addQuickElement(name=model_field, contents=error)
         xml.endElement("model-errors")
     xml.endElement("django-error")
     xml.endDocument()
     return response
예제 #7
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        Renders `data` into serialized XML.
        """
        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, self.charset)
        xml.startDocument()
        # If we do not have users or request_user then we have errors
        if not data.get('users', False) and not data.get(
                'request_user', False):
            self._to_errors(data, xml)
            xml.endDocument()
            return stream.getvalue()

        # If users are a list, deal with that
        if type(data['users']) is QuerySet or type(data['users']) is list:
            xml.startElement('people', {'type': 'array'})

            self._to_xml(data['users'], data['request_user'], xml)

            xml.endElement('people')
        # Otherwise just render a person
        else:
            self.render_person(data['users'], data['request_user'], xml)
        xml.endDocument()
        return stream.getvalue()
예제 #8
0
def dump_xml(data):
    """Simple function to convert python data structures to xml."""
    def _to_xml(xml, data):
        if isinstance(data, dict):
            for key, value in data.iteritems():
                key = force_unicode(key)
                xml.startElement(key, {})
                _to_xml(xml, value)
                xml.endElement(key)
        elif hasattr(data, '__iter__'):
            for item in data:
                xml.startElement("resource", {})
                _to_xml(xml, item)
                xml.endElement("resource")
        else:
            xml.characters(force_unicode(data))

    stream = StringIO.StringIO()
    
    xml = SimplerXMLGenerator(stream, "utf-8")
    xml.startDocument()
    xml.startElement("response", {})
    
    _to_xml(xml, data)
    
    xml.endElement("response")
    xml.endDocument()
    
    return stream.getvalue()
예제 #9
0
def xml_serialize(data):
    def to_xml(self, xml, data):
        if isinstance(data, (list, tuple)):
            for item in data:
                xml.startElement('resource', {})
                to_xml(xml, item)
                xml.endElement('resource')
        elif isinstance(data, dict):
            for key, value in data.iteritems():
                xml.startElement(key, {})
                to_xml(xml, value)
                xml.endElement(key)
        else:
            xml.characters(smart_unicode(data))

    stream = StringIO.StringIO()

    xml = SimplerXMLGenerator(stream, 'utf-8')
    xml.startDocument()
    xml.startElement('response', {})

    to_xml(xml, base_serialize(data))

    xml.endElement('response')
    xml.endDocument()

    return stream.getvalue()
예제 #10
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        Renders `data` into serialized XML.
        """
        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, self.charset)
        xml.startDocument()
        # If we do not have users or request_user then we have errors
        if not data.get('users', False) and not data.get('request_user', False):
            self._to_errors(data, xml)
            xml.endDocument()
            return stream.getvalue()

        # If users are a list, deal with that
        if type(data['users']) is QuerySet or type(data['users']) is list:
            xml.startElement('people', {'type': 'array'})

            self._to_xml(data['users'], data['request_user'], xml)

            xml.endElement('people')
        # Otherwise just render a person
        else:
            self.render_person(data['users'], data['request_user'], xml)
        xml.endDocument()
        return stream.getvalue()
예제 #11
0
    def render(self, data, *args, **kwargs):
        charset = 'utf-8'
        root_node = 'xforms'
        xmlns = "http://openrosa.org/xforms/xformsList"

        if 'detail' in data.keys():
            stream = StringIO()

            xml = SimplerXMLGenerator(stream, charset)
            xml.startDocument()
            xml.startElement(root_node, {'xmlns': xmlns})

            for key, value in six.iteritems(data):
                xml.startElement(key, {})
                xml.characters(smart_text(value))
                xml.endElement(key)

            xml.endElement(root_node)
            xml.endDocument()
            return stream.getvalue()
        else:
            json = self.transform_to_xform_json(data)
            survey = create_survey_element_from_dict(json)
            xml = survey.xml()
            fix_languages(xml)
            xml = xml.toxml()

            xml = self.insert_version_attribute(xml,
                                                data.get('id_string'),
                                                data.get('version'))
            xml = self.insert_uuid_bind(xml, data.get('id_string'))

            return xml
예제 #12
0
 def render(self, request):
     stream = StringIO.StringIO()
     xml = SimplerXMLGenerator(stream, "utf-8")
     xml.startDocument()
     self._to_xml(xml, self.construct())
     xml.endDocument()
     return stream.getvalue()
예제 #13
0
def WebFinger_HostMeta(request):
    res = HttpResponse(content_type="application/xml")
    xmlHandle = SimplerXMLGenerator(res, settings.DEFAULT_CHARSET)
    xmlHandle.startDocument()
    xmlHandle.startElement("XRD", {"xmlns": "http://docs.oasis-open.org/ns/xri/xrd-1.0"})
    xmlHandle.addQuickElement("Link", attrs={"rel": "lrdd", "type": "application/xrd+xml", "template": "https://" + settings.CP_ENDPOINT + "/.well-known/webfinger?resource={uri}"})
    xmlHandle.endElement("XRD")
    xmlHandle.endDocument()
    return res
예제 #14
0
    def render(self, data, prettyprint=False):
        """
            parameters:
              data = dictionary of the things to be shown
              prettyprint = flag for pretty printing the xml output (including whitespace and linebreaks)
            """

        stream = StringIO()
        xml = SimplerXMLGenerator(stream, self.charset)

        xml.startDocument()

        # add a comment
        xml._write(self.comment)

        # add namespace definitions
        nsattrs = {}
        nsattrs['version'] = self.version
        #nsattrs['encoding'] = charser
        nsattrs['xmlns:vosi'] = self.ns_vosiavail
        #nsattrs['xmlns:xsi'] = self.ns_xsi
        #nsattrs['xmlns:vs'] = self.ns_vs

        # add root node
        xml.startElement('vosi:availability', nsattrs)

        # add mandatory node:
        xml.startElement('vosi:available', {})
        xml.characters(smart_unicode(data['available']))
        xml.endElement('vosi:available')

        # remove available from data dict
        data.pop('available', None)

        # add possible optional nodes:
        for key in data.keys():
            xml.startElement('vosi:' + key, {})
            xml.characters(smart_unicode(data[key]))
            xml.endElement('vosi:' + key)

        xml.endElement('vosi:availability')

        xml.endDocument()

        xml_string = stream.getvalue()

        # make the xml pretty, i.e. use linebreaks and indentation
        # the sax XMLGenerator behind SimpleXMLGenerator does not seem to support this,
        # thus need a library that can do it.
        # TODO: since we use lxml anyway, maybe build the whole xml-tree with lxml.etree!
        # NOTE: This removes any possibly existing comments from the xml output!
        if prettyprint is True:
            parsed = etree.fromstring(xml_string)
            pretty_xml = etree.tostring(parsed, pretty_print=True)
            xml_string = pretty_xml

        return xml_string
예제 #15
0
def xml(request, data):
    stream = StringIO()
    xml = SimplerXMLGenerator(stream, "utf-8")
    xml.startDocument()
    xml.startElement("response", {})
    to_xml(xml, data)
    xml.endElement("response")
    xml.endDocument()
    return stream.getvalue()
예제 #16
0
 def render(self,):
     stream = StringIO.StringIO()
     xml = SimplerXMLGenerator(stream, "utf-8")
     xml.startDocument()
     xml.startElement(self.root_element, {})
     self._to_xml(xml, self.data_dict)
     xml.endElement(self.root_element)
     xml.endDocument()
     return stream.getvalue()
예제 #17
0
 def render(self, request, data, *, response_status):
     stream = StringIO()
     xml = SimplerXMLGenerator(stream, "utf-8")
     xml.startDocument()
     xml.startElement("data", {})
     self._to_xml(xml, data)
     xml.endElement("data")
     xml.endDocument()
     return stream.getvalue()
예제 #18
0
 def render(self, request):
     stream = StringIO.StringIO()
     xml = SimplerXMLGenerator(stream, "utf-8")
     xml.startDocument()
     xml.startElement("Response", {})
     self._to_xml(xml, self.construct())
     xml.endElement("Response")
     xml.endDocument()
     return stream.getvalue()
예제 #19
0
 def render(self, obj, stream, **opts):
     xml = SimplerXMLGenerator(stream, 'utf-8')
     xml.startDocument()
     xml.startElement('django-objects', {'version': '1.0'})
     if hasattr(obj, '__iter__'):
         [self.model_to_xml(xml, item) for item in obj]
     else:
         self.model_to_xml(xml, obj)
     xml.endElement('django-objects')
     xml.endDocument()
예제 #20
0
 def render(self, obj, stream, **opts):
     xml = SimplerXMLGenerator(stream, 'utf-8')
     xml.startDocument()
     xml.startElement('django-objects', {'version': '1.0'})
     if hasattr(obj, '__iter__'):
         [self.model_to_xml(xml, item) for item in obj]
     else:
         self.model_to_xml(xml, obj)
     xml.endElement('django-objects')
     xml.endDocument()
예제 #21
0
파일: models.py 프로젝트: omab/django-tcms
    def to_xml(self, out, encoding=settings.DEFAULT_CHARSET):
        """Exports page data in a XML formated file. It stores
        page info as first item and value data following it.
        Files are base64 encoded and exported too.

        Example:
        <cms-page>
          <page path="/path/" template="homepage" description="Homepage"
                locale="en-gb" meta_title="Title" meta_description="Description"
                meta_keywords="Keywords" search_image="base64 encoded image"
                search_image_name="file name of search image"
                search_text="Search text"></page>
          <value name="heading" type="text" value="Page title"></value>
          <value name="an_image" type="image" value="bas64 enconded"></value>
          ...
        </cms-page>
        """
        xml = SimplerXMLGenerator(out=out, encoding=encoding)
        xml.startDocument()
        xml.startElement("cms-page", {})

        # store page info in first child
        data = {
            "path": self.path.path,
            "template": self.template,
            "description": self.description,
            "locale": self.path.locale,
            "meta_title": self.meta_title,
            "meta_description": self.meta_description,
            "meta_keywords": self.meta_keywords,
            "search_text": self.search_text,
        }
        if self.search_image:  # add image content if any
            img = image_to_b64(self.search_image)
            if img is not None:
                name, content = img
                data["search_image_name"] = name
                data["search_image"] = content

        xml.startElement("page", data)
        xml.endElement("page")

        # store values
        values = self.values.values_list("name", "type", "value")
        for name, value_type, value in values:
            attrs = {"name": name, "type": value_type, "value": value}

            if value_type in TYPES_MAP:
                attrs.update(TYPES_MAP[value_type]().to_xml(value))
            xml.startElement("value", attrs)
            xml.endElement("value")

        xml.endElement("cms-page")
        xml.endDocument()
        return out
예제 #22
0
 def render(self):
     stream = StringIO.StringIO()
     xml = SimplerXMLGenerator(stream, "utf-8")
     xml.startDocument()
     xml.startElement('response', {'version':getattr(settings, 'API_VERSION', '1.0')})
     xml.startElement('request', {'path':self.request.path})
     xml.endElement('request')
     self._xml(xml, self.construct(), resource_name=None)
     xml.endElement('response')
     xml.endDocument()
     return stream.getvalue()
예제 #23
0
 def get_xml(self, data, item_name):
     if data is None:
         return ''
     stream = StringIO()
     xml = SimplerXMLGenerator(stream, self.charset)
     xml.startDocument()
     xml.startElement(self.root_tag_name, {})
     self._to_xml(xml, data, item_name, 0)
     xml.endElement(self.root_tag_name)
     xml.endDocument()
     return stream.getvalue()
예제 #24
0
    def dict2xml(self, data):
        stream = StringIO.StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("root", {})

        self._to_xml(xml, data)

        xml.endElement("root")
        xml.endDocument()
        return stream.getvalue()
예제 #25
0
 def render(self, response):
     if self.format != XMLResponseEncoder.format:
         return super(XMLResponseEncoder, self).render(response)
     stream = StringIO()
     xml = SimplerXMLGenerator(stream, "utf-8")
     xml.startDocument()
     xml.startElement("response", {})
     self._to_xml(xml, response)
     xml.endElement("response")
     xml.endDocument()
     content = stream.getvalue()
     return HttpResponse(content, mimetype=XMLResponseEncoder.mimetype)
예제 #26
0
파일: renderers.py 프로젝트: johlton/rdmo
    def render(self, data):

        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        self.render_document(xml, data)
        xml.endDocument()
        return stream.getvalue()
예제 #27
0
def sitemap_generator(request, maps, page, current_site):
    output = StringIO()
    protocol = request.is_secure() and 'https' or 'http'
    xml = SimplerXMLGenerator(output, settings.DEFAULT_CHARSET)
    xml.startDocument()
    xml.startElement(
        'urlset', {'xmlns': 'http://www.sitemaps.org/schemas/sitemap/0.9'})
    yield output.getvalue()
    pos = output.tell()
    for site in maps:
        if callable(site):
            if issubclass(site, RequestSitemap):
                site = site(request=request)
            else:
                site = site()
        elif hasattr(site, 'request'):
            site.request = request

        try:
            urls = site.get_urls(page=page, site=current_site,
                                 protocol=protocol)
        except InvalidPage:
            raise Http404('Page not found')

        for url in urls:
            xml.startElement('url', {})
            xml.addQuickElement('loc', url['location'])
            try:
                if url['lastmod']:
                    xml.addQuickElement(
                        'lastmod', url['lastmod'].strftime('%Y-%m-%d'))
            except (KeyError, AttributeError):
                pass
            try:
                if url['changefreq']:
                    xml.addQuickElement('changefreq', url['changefreq'])
            except KeyError:
                pass
            try:
                if url['priority']:
                    xml.addQuickElement('priority', url['priority'])
            except KeyError:
                pass
            xml.endElement('url')
            output.seek(pos)
            yield output.read()
            pos = output.tell()
    xml.endElement('urlset')
    xml.endDocument()
    output.seek(pos)
    last = output.read()
    output.close()
    yield last
예제 #28
0
 def render(self, response):
     if self.format != XMLResponseEncoder.format:
         return super(XMLResponseEncoder, self).render(response)
     stream = StringIO()
     xml = SimplerXMLGenerator(stream, "utf-8")
     xml.startDocument()
     xml.startElement("response", {})
     self._to_xml(xml, response)
     xml.endElement("response")
     xml.endDocument()
     content = stream.getvalue()
     return HttpResponse(content, mimetype=XMLResponseEncoder.mimetype)
예제 #29
0
    def dict2xml(self, data):
        stream = StringIO.StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("root", {})

        self._to_xml(xml, data)

        xml.endElement("root")
        xml.endDocument()
        return stream.getvalue()
예제 #30
0
    def render(self, request):
        stream = StringIO.StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("op_content", {})

        self._to_xml(xml, self.construct(), item_name = self._get_item_name())

        xml.endElement("op_content")
        xml.endDocument()

        return stream.getvalue()
예제 #31
0
    def encode(self, request, converted_data, resource, result, field_name_list):
        stream = StringIO.StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("response", {})

        self._to_xml(xml, converted_data)

        xml.endElement("response")
        xml.endDocument()

        return stream.getvalue()
예제 #32
0
    def render(self, request):
        stream = io.BytesIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("response", {})

        self._to_xml(xml, self.construct())

        xml.endElement("response")
        xml.endDocument()

        return stream.getvalue()
예제 #33
0
 def render(self, data, accepted_media_type=None, renderer_context=None):
     if data is None:
         return ''
     view = (renderer_context.get("view") if renderer_context else None)
     self.item_tag_name = getattr(view, "item_tag_name", self.item_tag_name)
     self.root_tag_name = getattr(view, "root_tag_name", self.root_tag_name)
     stream = io.StringIO()
     xml = SimplerXMLGenerator(stream, self.charset)
     xml.startDocument()
     root_tag_name = (getattr(data, "xml_tag", None) or self.root_tag_name)
     self._to_xml(xml, data, root_tag_name)
     xml.endDocument()
     return stream.getvalue()
 def render(self, data, accepted_media_type=None, renderer_context=None):
     """
     Renders `data` into serialized XML without the root tag. The root tag was added in the default
     XMLRenderer. So this CustomXMLRenderer removes it by overriding XMLRenderer class.
     """
     if data is None:
         return ''
     stream = StringIO()
     xml = SimplerXMLGenerator(stream, self.charset)
     xml.startDocument()
     self._to_xml(xml, data)
     xml.endDocument()
     return stream.getvalue()
예제 #35
0
    def render(self, request, post_processor=None):
        stream = StringIO.StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("response", {})

        self._to_xml(xml, self.construct(post_processor=post_processor))

        xml.endElement("response")
        xml.endDocument()

        return stream.getvalue()
 def render(self, data, accepted_media_type=None, renderer_context=None):
     """
     Renders `data` into serialized XML without the root tag. The root tag was added in the default
     XMLRenderer. So this CustomXMLRenderer removes it by overriding XMLRenderer class.
     """
     if data is None:
         return ''
     stream = StringIO()
     xml = SimplerXMLGenerator(stream, self.charset)
     xml.startDocument()
     self._to_xml(xml, data)
     xml.endDocument()
     return stream.getvalue()
예제 #37
0
 def render(self, data, accepted_media_type=None, renderer_context=None):
     if data is None:
         return ''
     view = (renderer_context.get("view") if renderer_context else None)
     self.item_tag_name = getattr(view, "item_tag_name", self.item_tag_name)
     self.root_tag_name = getattr(view, "root_tag_name", self.root_tag_name)
     stream = StringIO()
     xml = SimplerXMLGenerator(stream, self.charset)
     xml.startDocument()
     root_tag_name = (getattr(data, "xml_tag", None) or self.root_tag_name)
     self._to_xml(xml, data, root_tag_name)
     xml.endDocument()
     return stream.getvalue()
예제 #38
0
    def encode(self, request, converted_data, resource, result):
        stream = cStringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("response", {})

        self._to_xml(xml, converted_data)

        xml.endElement("response")
        xml.endDocument()

        return stream.getvalue()
예제 #39
0
    def encode(self, data, **kwargs):
        stream = cStringIO()

        xml = SimplerXMLGenerator(stream, 'utf-8')
        xml.startDocument()
        xml.startElement('response', {})

        self._to_xml(xml, data)

        xml.endElement('response')
        xml.endDocument()

        return stream.getvalue()
예제 #40
0
    def get_xml_export(self, context):
        results = self._get_objects(context)
        stream = StringIO.StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("objects", {})

        self._to_xml(xml, results)

        xml.endElement("objects")
        xml.endDocument()

        return stream.getvalue().split('\n')[1]
예제 #41
0
    def get_xml_export(self, context):
        results = self._get_objects(context)
        stream = StringIO.StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("objects", {})

        self._to_xml(xml, results)

        xml.endElement("objects")
        xml.endDocument()

        return stream.getvalue().split('\n')[1]
예제 #42
0
    def _format_data(self, data, charset):
        """ Format data into XML. """

        if data is None or data == '':
            return u''

        stream = StringIO.StringIO()
        xml = SimplerXMLGenerator(stream, charset)
        xml.startDocument()
        xml.startElement(self._root_element_name(), {})
        self._to_xml(xml, data)
        xml.endElement(self._root_element_name())
        xml.endDocument()
        return stream.getvalue()
예제 #43
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        In case a request is called on /api/v1/, we now redirect the call to DRF instead of
        Tastypie. The differences between DRF and Tastypie are:

        - Different names and values for several fields (see _rename_fields).

        On paginated results:
          - An additional 'meta' object containing the limit, next, previous and total_count;
          - Next and previous links do not show the domain;
          - The root tag name is 'response';
          - The tag name of the results is 'objects';
          - The tag name for each result is 'object'.

        On non-paginated results:
          - The tag name of the result is 'object'.
        """
        request = renderer_context.get('request')

        if '/api/v1/' in request.path:
            if data is None:
                return ''

            stream = StringIO()
            xml = SimplerXMLGenerator(stream, self.charset)
            xml.startDocument()

            if all(k in data.keys() for k in
                   ['count', 'next', 'previous', 'offset', 'results']):
                # Paginated result
                xml.startElement("response", {})
                data = _convert_data_for_tastypie(request,
                                                  renderer_context['view'],
                                                  data)
                self._to_xml(xml, data)
                xml.endElement("response")
            else:
                # Non-paginated result
                xml.startElement("object", {})
                self._to_xml(xml, _rename_fields([data])[0])
                xml.endElement("object")

            xml.endDocument()
            return stream.getvalue()
        elif isinstance(data, dict) and 'offset' in data.keys():
            data.pop('offset')

        return XMLRenderer().render(data, accepted_media_type,
                                    renderer_context)
예제 #44
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        if data is None:
            return ""

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, self.charset)
        xml.startDocument()
        xml.startElement(self.root_tag_name, attributes)

        self._to_xml(xml, data)

        xml.endElement(self.root_tag_name)
        xml.endDocument()
        return stream.getvalue()
예제 #45
0
    def get_xml_export(self, context):
        results = self._get_objects(context)

        stream = six.BytesIO()

        xml = SimplerXMLGenerator(stream, self.export_unicode_encoding)
        xml.startDocument()
        xml.startElement("objects", {})

        self._to_xml(xml, results)

        xml.endElement("objects")
        xml.endDocument()

        return stream.getvalue().split((b'\n'))[1]
예제 #46
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        Renders `data` into serialized XML.
        """
        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, self.charset)
        xml.startDocument()
        xml.startElement(self.root_tag_name, {})

        self._to_xml(xml, data)

        xml.endElement(self.root_tag_name)
        xml.endDocument()

        #raise AssertionError(type(stream.getvalue()));
        generic_xml = stream.getvalue()

        if data.get('count') != None and data.get('list') != None:
            # deal with multiple tools
            xmlfile = 'multiple.xslt'
        else:
            # deal with a single tool
            xmlfile = 'framework_XML_to_biotoolsSchema_3.3.0_XML_xslt1.0.xslt'

        try:
            xslt1 = lxmletree.parse(
                '/elixir/application/backend/elixir/biotoolsSchema/' + xmlfile)
            transform1 = lxmletree.XSLT(xslt1)
            dom = lxmletree.fromstring(generic_xml)
            newdom = transform1(dom)

            # removing empty elements
            xslt2 = lxmletree.parse(
                "/elixir/application/backend/elixir/biotoolsSchema/removeEmptyElements.xslt"
            )
            transform2 = lxmletree.XSLT(xslt2)
            newdom2 = transform2(newdom)

        except (lxmletree.XMLSyntaxError, Exception) as e:
            raise ParseError(
                'XML error - %s. Please notify [email protected] if you see this error. '
                % e)

        return lxmletree.tostring(newdom2)
예제 #47
0
파일: views.py 프로젝트: kriwil/labster
    def get(self, request, *args, **kwargs):

        stream = StringIO()
        xml = SimplerXMLGenerator(stream, self.charset)
        xml.startDocument()
        xml.startElement(self.root_name, self.get_root_attributes())

        self.insert_children(xml)

        xml.endElement(self.root_name)
        xml.endDocument()

        response = HttpResponse(stream.getvalue())
        response["Content-Type"] = "text/xml; charset={}".format(self.charset)

        return response
예제 #48
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        Renders `data` into serialized XML.
        """
        if data is None:
            return ""

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, self.charset)
        xml.startDocument()

        self._to_xml(xml, data)

        xml.endDocument()
        return stream.getvalue()
예제 #49
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, self.charset)
        xml.startDocument()

        if isinstance(data, (list, tuple)):
            self._render_list(data, xml, renderer_context)
        elif isinstance(data, dict):
            self._render_dict(data, xml, renderer_context)

        xml.endDocument()
        return stream.getvalue()
예제 #50
0
파일: renderers.py 프로젝트: delving/nave
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        Renders `data` into serialized XML.
        """
        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, encoding=self.charset)
        xml.startDocument()

        self._to_xml(xml, data)

        xml.endDocument()
        return stream.getvalue()
예제 #51
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, self.charset)
        xml.startDocument()

        if isinstance(data, (list, tuple)):
            self._render_list(data, xml, renderer_context)
        elif isinstance(data, dict):
            self._render_dict(data, xml, renderer_context)

        xml.endDocument()
        return stream.getvalue()
예제 #52
0
    def _encode(self, data, **kwargs):
        if data is not None:
            stream = StringIO()

            xml = SimplerXMLGenerator(stream, 'utf-8')
            xml.startDocument()
            xml.startElement('response', {})

            self._to_xml(xml, data)

            xml.endElement('response')
            xml.endDocument()

            return stream.getvalue()
        else:
            return ''
예제 #53
0
    def render(self, request):
        stream = StringIO.StringIO()

        xml = SimplerXMLGenerator(stream, 'utf-8')
        xml.startDocument()
        data = self.construct()
        if isinstance(data, (list, tuple)):
            root_node = force_unicode(self.handler.model._meta.verbose_name_plural)
        else:
            root_node = force_unicode(self.handler.model._meta.verbose_name)

        xml.startElement(root_node, {})
        self._to_xml(xml, self.construct())
        xml.endElement(root_node)
        xml.endDocument()

        return stream.getvalue()
예제 #54
0
class Serializer(NonrelationalSerializer):        
    def indent(self, level):
        if self.options.get('indent') is not None:
            self.xml.ignorableWhitespace('\n' + ' ' * self.options.get('indent') * level)

    def start_serialization(self):
        self.xml = SimplerXMLGenerator(self.stream, self.options.get("encoding", settings.DEFAULT_CHARSET))
        self.xml.startDocument()
        self.xml.startElement("django-objects", {"version": "1.0"})
        
    def end_serialization(self):
        self.indent(0)
        self.xml.endElement("django-objects")
        self.xml.endDocument()
                
    def start_object(self, obj):
        self.verify_object_is_model(obj)
        
        self.indent(1)
        attrs = {'model': self.model_path(obj)}
        obj_pk = obj.pk
        if obj_pk is not None:
            attrs['pk'] = str(obj_pk)
        self.xml.startElement("object", attrs)
          
    def end_object(self, obj):
        self.indent(1)
        self.xml.endElement("object")
                         
    def handle_field(self, obj, field):
        self.indent(2)
        self.xml.startElement('field', {
            'name': field.name,
            'type': self.field_type(field),
        })
        
        if getattr(obj, field.name) is not None:
            try:
                self.xml.characters(field.value_to_string(obj))
            except UnserializableContentError:
                raise ValueError("%s.%s (pk:%s) contains unserializable characters" % (
                    obj.__class__.__name__, field.name, obj.pk))
        else:
            self.xml.addQuickElement("None")
        self.xml.endElement("field")
예제 #55
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        In case a request is called on /api/v1/, we now redirect the call to DRF instead of
        Tastypie. The differences between DRF and Tastypie are:

        - Different names and values for several fields (see _rename_fields).

        On paginated results:
          - An additional 'meta' object containing the limit, next, previous and total_count;
          - Next and previous links do not show the domain;
          - The root tag name is 'response';
          - The tag name of the results is 'objects';
          - The tag name for each result is 'object'.

        On non-paginated results:
          - The tag name of the result is 'object'.
        """
        request = renderer_context.get('request')

        if '/api/v1/' in request.path:
            if data is None:
                return ''

            stream = StringIO()
            xml = SimplerXMLGenerator(stream, self.charset)
            xml.startDocument()

            if all(k in data.keys() for k in ['count', 'next', 'previous', 'offset', 'results']):
                # Paginated result
                xml.startElement("response", {})
                data = _convert_data_for_tastypie(request, renderer_context['view'], data)
                self._to_xml(xml, data)
                xml.endElement("response")
            else:
                # Non-paginated result
                xml.startElement("object", {})
                self._to_xml(xml, _rename_fields([data])[0])
                xml.endElement("object")

            xml.endDocument()
            return stream.getvalue()
        elif isinstance(data, dict) and 'offset' in data.keys():
            data.pop('offset')

        return XMLRenderer().render(data, accepted_media_type, renderer_context)
예제 #56
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        Renders *obj* into serialized XML.
        """
        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("root", {})

        self._to_xml(xml, data)

        xml.endElement("root")
        xml.endDocument()
        return stream.getvalue()
예제 #57
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        if data is None:
            return ''

        stream = StringIO()
        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()

        self._to_xml(xml, data)

        xml.endDocument()
        response = stream.getvalue()

        if self.strip_declaration:
            declaration = '<?xml version="1.0" encoding="utf-8"?>'
            if response.startswith(declaration):
                response = response[len(declaration):]
        return response.strip()
예제 #58
0
    def render(self, data, accepted_media_type=None, renderer_context=None):
        """
        Renders *obj* into serialized XML.
        """
        if data is None:
            return ''

        stream = StringIO()

        xml = SimplerXMLGenerator(stream, "utf-8")
        xml.startDocument()
        xml.startElement("root", {})

        self._to_xml(xml, data)

        xml.endElement("root")
        xml.endDocument()
        return stream.getvalue()