Clearing workflow automation for SW360
Project description
CaPyWfa - Clearing workflow automation for SW360
Main goal of this project is to automate submission of Open Source packages to the SW360 component catalogue, e.g. for license clearing. It is based on CaPyCli.
For now, this is mainly used for Debian and Alpine Linux packages, but most of our building blocks might be helpful for clearing of large collections of (linux) packages in general.
Clearing tools
**Please refer to ChangeLog.md for latest changes.
These tools are designed to provide full automation e.g. for integration in CI pipelines, but at the same time we stay a friendly neighbour to users creating SW360 entries interactively. Major design decisions:
- We rely on Package URLs to identify software components and versions. We mostly avoid heuristics.
- We try hard to not create duplicates. Existing components, releases and attachments will be re-used if they can be identified by Package URLs.
- If no matching component is found, the SBOM item will be skipped and the user is asked to manually identify existing components, add package URLs and re-run the tool.
- New components can be created if the user adds additional meta-data to the SBOM e.g. to specify the component name, homepage and description. Please use upstream names like e.g. "Perl::Critic" instead of Debian's "libperl-critic-perl".
- Existing attachments are verified. If the hash doesn't match, the scripts try to automatically download, extract and compare existing attachments.
Also note that for now, the scripts will only handle source packages. No entries, package URLs etc. will be added for binary packages. In other words: we only create SW360 releases, but don't support the SW360 package portlet yet.
Overview
Your main entry point is capywfa/capywfa.py. This section explains the general
workflow. For details how to install and run the tools, see the next sections!
CaPyWfa will perform the following tasks:
- Identify existing components (packages) and releases (versions) in SW360.
- Ask user to download missing sources.
- Verify existing SW360 sources are correct (using the
verify_sources.pyscript internally -- which can also be called separately). - Create missing components and releases in SW360 and upload sources.
- Link SW360 releases to your SW360 project.
- Show you a summary if packages couldn't be processed automatically, exit code for incomplete uploads: 81
capywfa.py expects a CycloneDX SBOM, so
you have to convert your package list first:
# convert Debian or Alpine package list to Standard BOM format:
$ lst_to_sbom.py <deb|apk> <package-list> package-list.json
Now, check capywfa.py --help for the necessary parameters. The tool will guide
you through the process. Note that it will write an updated BOM after each step.
In general, it should be safe to interrupt the tool and re-run it at any time.
Using the output BOM from the last step will save some time in repeated runs.
If not all components can be identified automatically, you need to manually search the components in SW360 and add their component Id to the BOM or add the PackageURL to SW360. The tool will offer to download a list of all components if you prefer offline search.
Components which do not exist in SW360 can be created by capywfa -- this requires you to add some meta information to the BOM (Homepage, Categories, Description).
Running directly on a Linux system
You can clone this repository and run the scripts directly.
CaPyWfa should run on any recent system with Python >= 3.8.
To run the scripts in a Python "virtual environment" with all needed dependencies, we use Poetry
poetry install
poetry run python3 ./capywfa/capywfa.py ...
Installing as Python package (experimental)
TODO: Not available on Github/PyPI yet.
SW360 project verification
With the help of the capycli command and small helper scripts which are
part of the Poetry and Docker environments, you can verify that the upload
succeeded and already existing releases have correct sources and meta data:
$ python3 -m capycli bom Map --nocache -i packages-list.json -t <sw360-token> -oa -o packages-mapped.json
[...]
Mapping result:
Full match by id, at, 3.1.23-1.debian => at daemon, 3.1.23-1.debian, b0667b7334c070cd2f05b071265ce7b3
[...]
$ python3 -m capycli project Prerequisites -id <project-id> -i packages-mapped.json -t <token> -oa
[...]
Components:
software-properties, 0.96.20.2-2.debian: OPEN
Download URL: http://deb.debian.org/debian/pool/main/s/software-properties_0.96.20.2-2.dsc
SHA1 for source software-properties_0.96.20.2-2-debian-combined.tar.bz2 doesn't match!
1 source file(s) available.
component management id: {'package-url': 'pkg:deb/debian/software-properties@0.96.20.2-2?arch=source'}
[...]
Credits
These tools were developed by Siemens AG, with primary funding from Siemens Healthineers AG.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file capywfa-0.11.0.tar.gz.
File metadata
- Download URL: capywfa-0.11.0.tar.gz
- Upload date:
- Size: 15.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eada47c27767940a582425de21961c51dfe3042fe1464244d7ed51d288454bdf
|
|
| MD5 |
f8b7067e8b7bc281285e63b99ac84138
|
|
| BLAKE2b-256 |
075af2cd4ed4e407e7b15a9fd68009b927c08a32e08abe970ac93b31c1814ead
|
Provenance
The following attestation bundles were made for capywfa-0.11.0.tar.gz:
Publisher:
publish-to-pypi.yml on sw360/capywfa
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
capywfa-0.11.0.tar.gz -
Subject digest:
eada47c27767940a582425de21961c51dfe3042fe1464244d7ed51d288454bdf - Sigstore transparency entry: 1293584147
- Sigstore integration time:
-
Permalink:
sw360/capywfa@11323f3d45c333b6de7282d99f1f6285a6c100cb -
Branch / Tag:
refs/tags/v0.11.0 - Owner: https://github.com/sw360
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@11323f3d45c333b6de7282d99f1f6285a6c100cb -
Trigger Event:
release
-
Statement type:
File details
Details for the file capywfa-0.11.0-py3-none-any.whl.
File metadata
- Download URL: capywfa-0.11.0-py3-none-any.whl
- Upload date:
- Size: 17.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
18b4e4b77c739a87e81e355fa3c03188455cf1c5c0c0df70bfa10d637638ae55
|
|
| MD5 |
7dc7c6c8dc1f7c4f446c11a4275ce662
|
|
| BLAKE2b-256 |
7f85178259e99c4297936075c50a2c537e0e916f6da99499d76d5ffacd2aec23
|
Provenance
The following attestation bundles were made for capywfa-0.11.0-py3-none-any.whl:
Publisher:
publish-to-pypi.yml on sw360/capywfa
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
capywfa-0.11.0-py3-none-any.whl -
Subject digest:
18b4e4b77c739a87e81e355fa3c03188455cf1c5c0c0df70bfa10d637638ae55 - Sigstore transparency entry: 1293584172
- Sigstore integration time:
-
Permalink:
sw360/capywfa@11323f3d45c333b6de7282d99f1f6285a6c100cb -
Branch / Tag:
refs/tags/v0.11.0 - Owner: https://github.com/sw360
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-to-pypi.yml@11323f3d45c333b6de7282d99f1f6285a6c100cb -
Trigger Event:
release
-
Statement type: