Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: support for deserialization from JSON and XML #290

Merged
merged 70 commits into from
Mar 3, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
70 commits
Select commit Hold shift + click to select a range
a5e9f78
chore: drop Python 3.6 support
hakandilek Dec 16, 2022
e0cb0b2
chore: regenerated poetry.lock
hakandilek Dec 17, 2022
279a316
Merge branch 'dev/4.0.0' into drop-python-3.6
madpah Jan 20, 2023
e244b38
Merge remote-tracking branch 'upstream/main' into drop-python-3.6
hakandilek Jan 20, 2023
448ebd6
Merge branch 'dev/4.0.0' into drop-python-3.6
hakandilek Jan 20, 2023
a3f5555
first deserialization test from JSON working
madpah Aug 15, 2022
eba9ca9
fixed related unit tests, removed `print()` call
madpah Aug 15, 2022
c2de5d6
first unit test passing deserializing XML BOM to Python Objects using…
madpah Aug 15, 2022
9cf02b7
wip - updated `serializable` to work based from decorators - 2 JSON u…
madpah Aug 19, 2022
3eadce6
bump `py-serializable` to `0.3.3`
madpah Aug 19, 2022
577955d
wip - 3 unit tests deserializing from xml working
madpah Aug 24, 2022
09dd543
wip - XML deserialization tests
madpah Aug 24, 2022
a81ed8c
wip - XML deserialization tests
madpah Aug 24, 2022
9ff03ba
fixed model tests
madpah Aug 24, 2022
aaf0574
wip to use `py-serializable` for output to XML
madpah Sep 6, 2022
37c12b2
wip: serialization tests to XMl passing for 1.4
madpah Sep 12, 2022
40357f4
JSON 1.4 unit tests passing except those blocked by https://github.co…
madpah Sep 13, 2022
9f88ce8
JSONv unit tests passing except those blocked by https://github.com/C…
madpah Sep 14, 2022
cff32e4
coding standards
madpah Sep 14, 2022
610cde1
XML deserialization unit test work
madpah Sep 15, 2022
dd44435
removed unit tests now invalid
madpah Sep 15, 2022
438c97d
typing and coding standards
madpah Sep 15, 2022
450dd41
chore: fix release workflow
madpah Sep 15, 2022
1ee369f
chore: bump dependencies
madpah Jan 20, 2023
d3981b5
chore: ensure py-serializable installed on py3.7
madpah Jan 20, 2023
6f74c81
fix: tests now passing
madpah Jan 23, 2023
102b991
Merge branch 'dev/4.0.0' into feat/deserialization-to-object-model
madpah Jan 23, 2023
6c2268e
chore: remove commented old code
madpah Jan 23, 2023
d5a57dd
merge fixes
madpah Jan 23, 2023
b042d8e
remove f-string
madpah Jan 23, 2023
b8dc10b
work on test data alignment
madpah Jan 23, 2023
b449419
fix: logic for building dependency graph lacked leaf nodes in some cases
madpah Jan 23, 2023
cd8c920
indentiation
madpah Jan 23, 2023
c74b1c8
Merge branch 'feat/deserialization-to-object-model' into drop-python-3.6
madpah Jan 23, 2023
ac390fe
Merge pull request #325 from hakandilek/drop-python-3.6
madpah Jan 23, 2023
1969218
chore: regenerated `poetry.lock`
madpah Jan 23, 2023
709fbe3
chore: bump `py-serializable` to latest (now BETA, was ALPHA)
madpah Jan 24, 2023
f85dc68
chore: remove dead code
madpah Jan 24, 2023
099a21b
chore: removed unused classes
madpah Jan 24, 2023
1866d01
doc: code docs added
madpah Jan 24, 2023
6b5ec7a
fix: changed parts of `LicenseChoiceFactory` and `LicenseFactory` to …
madpah Jan 24, 2023
1602c75
chore: replaced with f-string
madpah Jan 24, 2023
88097bd
chore: removed unused code and minor refactor to remove duplicate code
madpah Jan 24, 2023
329b68c
fix: various model issues preventing deserialization resolved + added…
madpah Jan 24, 2023
cce2bc8
further unit tests to ensure coverage for deserialization from XML
madpah Jan 24, 2023
dc76a2f
completed test coverage for deserialization from xml - few fixes incl…
madpah Jan 26, 2023
cb3538c
completed test coverage for deserialization from JSON - few fixes inc…
madpah Jan 26, 2023
714de0b
cleanup
madpah Jan 26, 2023
418bf56
chore: bump `py-serializable` to `0.9.1` as lowest supported
madpah Jan 26, 2023
51a4198
further testing and unit tests for JSON BOM deserialization
madpah Jan 26, 2023
c362254
use of UUID corrected within unit tests prior to completing JSON unit…
madpah Jan 27, 2023
a93d48c
further unit test fixes/alignments
madpah Jan 27, 2023
a185691
JSON unit tests now passing - still have https://github.com/CycloneDX…
madpah Jan 27, 2023
0f85fd4
removed unused imports
madpah Jan 27, 2023
48ae201
work to get (de-)serialization working for Dependencies given https:/…
madpah Feb 27, 2023
ab2b670
code style
madpah Feb 27, 2023
be97e0e
disabled logger for `serializable`
madpah Feb 27, 2023
b271e6c
`test_bom_v1_4_issue_275_components` failed but `test_bom_v1_3_issue_…
madpah Feb 27, 2023
18e9e1b
code style
madpah Feb 27, 2023
a88d19f
ci: corrected ci workflow
madpah Feb 27, 2023
6f3a7d9
further test - deserialization failing for BOM generated by CDX Maven…
madpah Mar 2, 2023
ebf7a7e
fix: upstream fix in `serializable` when deserializing BOMs with empt…
madpah Mar 2, 2023
212e4ce
code style
madpah Mar 2, 2023
bf46aa7
code style
madpah Mar 2, 2023
d9fef04
QA - addressed feedback from avoiding python `builtins` and `keywords…
madpah Mar 3, 2023
f9e742e
put factory back to a factory
madpah Mar 3, 2023
38e1352
code-style + test updates
madpah Mar 3, 2023
f043fff
fixed feedback provided by @sonatype-lift
madpah Mar 3, 2023
302fc79
addressed feedback from @jkowalleck
madpah Mar 3, 2023
ff6ffb3
addressed feedback from @jkowalleck
madpah Mar 3, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
19 changes: 5 additions & 14 deletions .github/workflows/poetry.yml
Original file line number Diff line number Diff line change
Expand Up @@ -56,8 +56,8 @@ jobs:
python-version: '3.10'
toxenv-factor: 'locked'
- # test with the lowest dependencies
os: ubuntu-20.04
python-version: '3.6'
os: ubuntu-latest
python-version: '3.7'
toxenv-factor: 'lowest'
steps:
- name: Checkout
Expand Down Expand Up @@ -93,22 +93,13 @@ jobs:
- "3.10" # highest supported
- "3.9"
- "3.8"
- "3.7"
- "3.6" # lowest supported
- "3.7" # lowest supported
toxenv-factor: ['locked']
include:
- # test with py36 ubuntu20
os: ubuntu-20.04
python-version: '3.6'
toxenv-factor: 'locked'
- # test with the lowest dependencies
os: ubuntu-20.04
python-version: '3.6'
toxenv-factor: 'lowest'
exclude:
- # no py36 with latest ubuntu - see https://raw.githubusercontent.com/actions/python-versions/main/versions-manifest.json
os: ubuntu-latest
python-version: '3.6'
python-version: '3.7'
toxenv-factor: 'lowest'
steps:
- name: Disabled Git auto EOL CRLF transforms
run: |
Expand Down
3 changes: 3 additions & 0 deletions cyclonedx/exception/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,4 +21,7 @@


class CycloneDxException(Exception):
"""
Root exception thrown by this library.
"""
pass
12 changes: 12 additions & 0 deletions cyclonedx/exception/factory.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,16 +30,28 @@ class CycloneDxFactoryException(CycloneDxException):


class LicenseChoiceFactoryException(CycloneDxFactoryException):
"""
Base exception that covers all LicenseChoiceFactory exceptions.
"""
pass


class InvalidSpdxLicenseException(LicenseChoiceFactoryException):
"""
Thrown when an invalid SPDX License is provided.
"""
pass


class LicenseFactoryException(CycloneDxFactoryException):
"""
Base exception that covers all LicenseFactory exceptions.
"""
pass


class InvalidLicenseExpressionException(LicenseFactoryException):
"""
Thrown when an invalid License expressions is provided.
"""
pass
7 changes: 7 additions & 0 deletions cyclonedx/exception/output.py
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,13 @@
from . import CycloneDxException


class BomGenerationErrorException(CycloneDxException):
"""
Raised if there is an unknown error.
"""
pass


class FormatNotSupportedException(CycloneDxException):
"""
Exception raised when attempting to output a BOM to a format not supported in the requested version.
Expand Down
4 changes: 4 additions & 0 deletions cyclonedx/factory/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,3 +14,7 @@
#
# SPDX-License-Identifier: Apache-2.0
# Copyright (c) OWASP Foundation. All Rights Reserved.

"""
Factories used in this library.
"""
21 changes: 9 additions & 12 deletions cyclonedx/factory/license.py
Original file line number Diff line number Diff line change
Expand Up @@ -30,27 +30,24 @@ def make_from_string(self, name_or_spdx: str, *,
license_url: Optional[XsUri] = None) -> License:
"""Make a :class:`cyclonedx.model.License` from a string."""
try:
return self.make_with_id(name_or_spdx, license_text=license_text, license_url=license_url)
return self.make_with_id(name_or_spdx, text=license_text, url=license_url)
except InvalidSpdxLicenseException:
return self.make_with_name(name_or_spdx, license_text=license_text, license_url=license_url)
return self.make_with_name(name_or_spdx, text=license_text, url=license_url)

def make_with_id(self, spdx_id: str, *,
license_text: Optional[AttachedText] = None,
license_url: Optional[XsUri] = None) -> License:
def make_with_id(self, spdx_id: str, *, text: Optional[AttachedText] = None,
url: Optional[XsUri] = None) -> License:
"""Make a :class:`cyclonedx.model.License` from an SPDX-ID.

:raises InvalidSpdxLicenseException: if `spdx_id` was not known/supported SPDX-ID
"""
spdx_license_id = spdx_fixup(spdx_id)
if spdx_license_id is None:
raise InvalidSpdxLicenseException(spdx_id)
return License(spdx_license_id=spdx_license_id, license_text=license_text, license_url=license_url)
return License(id=spdx_license_id, text=text, url=url)

def make_with_name(self, name: str, *,
license_text: Optional[AttachedText] = None,
license_url: Optional[XsUri] = None) -> License:
def make_with_name(self, name: str, *, text: Optional[AttachedText] = None, url: Optional[XsUri] = None) -> License:
"""Make a :class:`cyclonedx.model.License` with a name."""
return License(license_name=name, license_text=license_text, license_url=license_url)
return License(name=name, text=text, url=url)


class LicenseChoiceFactory:
Expand All @@ -74,12 +71,12 @@ def make_with_compound_expression(self, compound_expression: str) -> LicenseChoi
:raises InvalidLicenseExpressionException: if `expression` is not known/supported license expression
"""
if is_spdx_compound_expression(compound_expression):
return LicenseChoice(license_expression=compound_expression)
return LicenseChoice(expression=compound_expression)
raise InvalidLicenseExpressionException(compound_expression)

def make_with_license(self, name_or_spdx: str, *,
license_text: Optional[AttachedText] = None,
license_url: Optional[XsUri] = None) -> LicenseChoice:
"""Make a :class:`cyclonedx.model.LicenseChoice` with a license (name or SPDX-ID)."""
return LicenseChoice(license_=self.license_factory.make_from_string(
return LicenseChoice(license=self.license_factory.make_from_string(
name_or_spdx, license_text=license_text, license_url=license_url))
Loading