A library for querying the OSS Index free catalogue of open source components to help developers identify vulnerabilities, understand risk, and keep their software safe.
Project description
Python Library for quering OSS Index
This OSSIndex module for Python provides a common interface to querying the OSS Index.
This module is not designed for standalone use. If you're looking for a tool that can detect your application's dependencies and assess them for vulnerabilities against the OSS Index, perhaps you should check out Jake.
You can of course use this library in your own applications.
Installation
Install from pypi.org as you would any other Python module:
pip install ossindex-lib
Usage
First create an instance of OssIndex
, optionally enabling local caching
o = OssIndex()
Then supply a List
of PackageURL objects that you want to ask
OSS Index about. If you don't want to care about generating this list yourself, perhaps look to a tool like Jake
(which uses this library) and will do all the hard work for you!
As a quick test, you could run:
o = OssIndex()
results: List[OssIndexComponent] = o.get_component_report(packages=[
PackageURL.from_string(purl='pkg:pypi/pip@19.2.0')
])
for r in results:
print("{}: {} known vulnerabilities".format(r.get_coordinates(), len(r.get_vulnerabilities())))
v: Vulnerability
for v in r.get_vulnerabilities():
print(' - {}'.format(str(v)))
... which would output something like ...
pkg:pypi/pip@19.2.0: 1 known vulnerabilities
- <Vulnerability id=e4c955a3-2004-472e-920b-783fea46c3cd, name=OSSINDEX-783f-ea46-c3cd, cvss_score=3.6>
Logging
This library send log events to a standard Python logger
named ossindex
. You can configure the logger to output as
required through the standard Python logging configuration.
Todos
- Support authentication against OSS Index
Python Support
We endeavour to support all functionality for all current actively supported Python versions. However, some features may not be possible/present in older Python versions due to their lack of support.
Changelog
See our CHANGELOG.
The Fine Print
Remember:
It is worth noting that this is NOT SUPPORTED by Sonatype, and is a contribution of ours to the open source community (read: you!)
- Use this contribution at the risk tolerance that you have
- Do NOT file Sonatype support tickets related to
ossindex-lib
- DO file issues here on GitHub, so that the community can pitch in
Phew, that was easier than I thought. Last but not least of all - have fun!
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
File details
Details for the file ossindex-lib-1.1.1.tar.gz
.
File metadata
- Download URL: ossindex-lib-1.1.1.tar.gz
- Upload date:
- Size: 14.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.14 CPython/3.10.5 Darwin/21.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 06eff2263a067aceee8fb45e11300c7d80863c5e9bb13016b866df40b30fe9eb |
|
MD5 | 31db8f42767699bd5a06b9c37e80f7e0 |
|
BLAKE2b-256 | 445ced269f7104c6330c4b56e27e1177066901da8f5c4010f7ccc7995a51be67 |
File details
Details for the file ossindex_lib-1.1.1-py3-none-any.whl
.
File metadata
- Download URL: ossindex_lib-1.1.1-py3-none-any.whl
- Upload date:
- Size: 19.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.14 CPython/3.10.5 Darwin/21.6.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 6c3fbf3ab03feb20f281d6971b5a5398ce3e6b637687090f338efb7ab08e424c |
|
MD5 | 09871687f7d4d0db00014c1878fffb12 |
|
BLAKE2b-256 | 1f01db87a60575afafd66001db1b54d18e53e70f2f0a3ffad227563c73891e90 |