A Python library for interacting with Open Source Insights API (deps.dev).
Easily fetch package, version, project, advisory, container, and PURL data—and leverage automatic name normalization and hash encoding.
pip install pydepsdev
import asyncio
from pydepsdev.api import DepsdevAPI
async def main():
# Simple init
api = DepsdevAPI()
# …use api methods…
await api.close()
asyncio.run(main())
Or use as an async context manager:
import asyncio
from pydepsdev.api import DepsdevAPI
async def main():
async with DepsdevAPI() as api:
pkg_info = await api.get_package("npm", "foo")
print(pkg_info)
asyncio.run(main())
- System names are case‐insensitive but always sent uppercase.
- NuGet package names are lowercased.
- PyPI package names are normalized per [PEP 503].
- When you call
query_package_versions(hash_type, hash_value, …)
, yourhash_value
is automatically Base64‐encoded before sending.
# Get basic package info + versions list
await api.get_package(system_name: str, package_name: str)
# Get metadata for a specific version
await api.get_version(system_name: str, package_name: str, version: str)
# One page (up to 5000) of versions
await api.get_version_batch(
[(system, pkg, ver), …],
page_token: Optional[str] = None
)
# Retrieve ALL pages for a batch
await api.get_all_versions_batch(
[(system, pkg, ver), …]
)
# NuGet only
await api.get_requirements("NuGet", "package_name", "version")
# Any supported system
await api.get_dependencies(system_name, package_name, version)
# Dependent counts
await api.get_dependents(system_name, package_name, version)
# Go only
await api.get_capabilities("Go", "module_path", "version")
# Find similarly-named packages
await api.get_similarly_named_packages(system_name, package_name)
# By hash (hash.value is auto base64‐encoded)
await api.query_package_versions(
hash_type: str, # e.g. "SHA256"
hash_value: str, # raw hex or bytes
version_system: Optional[str] = None,
version_name: Optional[str] = None,
version: Optional[str] = None,
)
# Single project metadata
await api.get_project(project_id: str)
# One page of project batch
await api.get_project_batch(
[project_id1, project_id2, …],
page_token: Optional[str] = None
)
# Retrieve all pages
await api.get_all_projects_batch([…])
# List package versions derived from a project
await api.get_project_package_versions(project_id: str)
# Fetch OSV advisory details
await api.get_advisory(advisory_id: str)
# Single purl
await api.get_purl_lookup(purl: str)
# One page of PURL batch
await api.get_purl_lookup_batch(
[purl1, purl2, …],
page_token: Optional[str] = None
)
# Retrieve all pages
await api.get_all_purl_lookup_batch([…])
# Query container images by OCI chain ID
await api.query_container_images(chain_id: str)
For full details on parameters and response schemas, see the Deps.dev API docs.
Contributions, issues and feature requests are welcome!
Feel free to check issues page or submit a pull request.
This project is licensed under the Apache Software License 2.0.