From 3579484c05f58935b39e08cb0d9a62ab08046748 Mon Sep 17 00:00:00 2001 From: Jan Kowalleck Date: Fri, 22 Sep 2023 09:54:00 +0200 Subject: [PATCH] feat: xml output omit defaultNS identifier fixes #438 BREAKING CHANGE Signed-off-by: Jan Kowalleck --- cyclonedx/output/xml.py | 29 ++++++++++++----------------- 1 file changed, 12 insertions(+), 17 deletions(-) diff --git a/cyclonedx/output/xml.py b/cyclonedx/output/xml.py index a72e5041..c73b2cd5 100644 --- a/cyclonedx/output/xml.py +++ b/cyclonedx/output/xml.py @@ -52,31 +52,26 @@ def output_format(self) -> OutputFormat: return OutputFormat.XML def generate(self, force_regeneration: bool = False) -> None: - # New way - _view = SCHEMA_VERSIONS[self.schema_version_enum] - if self.generated and force_regeneration: + if force_regeneration or not self.generated: + _view = SCHEMA_VERSIONS[self.schema_version_enum] self.get_bom().validate() self._root_bom_element = self.get_bom().as_xml( # type: ignore view_=_view, as_string=False, xmlns=self.get_target_namespace() ) self.generated = True - return - elif self.generated: - return - else: - self.get_bom().validate() - self._root_bom_element = self.get_bom().as_xml( # type: ignore - view_=_view, as_string=False, xmlns=self.get_target_namespace() - ) - self.generated = True - return def output_as_string(self) -> str: self.generate() - if self.generated and self._root_bom_element is not None: - return str(Xml.XML_VERSION_DECLARATION + ElementTree.tostring(self._root_bom_element, encoding='unicode')) - - raise BomGenerationErrorException('There was no Root XML Element after BOM generation.') + if not self.generated or self._root_bom_element is None: + raise BomGenerationErrorException('There was no Root XML Element after BOM generation.') + ElementTree.register_namespace('', self.get_target_namespace()) + return ElementTree.tostring( + self._root_bom_element, method='xml', + encoding='unicode', xml_declaration=True, + # cannot set defaultNS, because the stupid XML serializer forgot to set NS on attributes. + # therefore, the defaultNS was registered as name with empty string. see above. + # default_namespace=self.get_target_namespace() + ) def get_target_namespace(self) -> str: return f'http://cyclonedx.org/schema/bom/{self.get_schema_version()}'