Analyze dependency licenses for Python projects, with compatibility checks and outbound license recommendations
Project description
license-audit
Analyze dependency licenses for Python projects.
license-audit tells you what license your project can use, flags incompatible combinations, and generates compliance documents suitable for CI gating.
Features
- License detection across the full transitive tree, from PEP 639 metadata, the legacy
Licensefield, trove classifiers, and user overrides. - Pairwise compatibility checking against the OSADL compatibility matrix (~120 licenses).
- Outbound license recommendations ranked by permissiveness.
- Compliance reports as Markdown, JSON, or third-party-notices.
- CI exit codes that distinguish policy violations from undetected licenses.
- Reads
uv.lock,poetry.lock,pixi.lock,pyproject.toml,requirements.txt, and live virtualenvs.
Installation
pip install license-audit
Or with uv:
uv add license-audit --dev
Quickstart
Run against the current project directory:
license-audit --target . analyze
License Analysis: my-project
Dependency Licenses
Package Version License Category Source Parent
click 8.1.7 BSD-3-Clause permissive pep639 (direct)
pydantic 2.9.2 MIT permissive pep639 (direct)
rich 13.9.4 MIT permissive pep639 (direct)
Recommended Outbound Licenses (most -> least permissive):
-> MIT
BSD-3-Clause
Apache-2.0
...
Summary
Total dependencies: 3
Policy check: PASSED
CI quickstart
Add to your pipeline to gate on license policy:
jobs:
license-check:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- uses: astral-sh/setup-uv@v5
- run: uv sync --locked
- run: uv run license-audit check
Exit codes:
| Code | Meaning |
|---|---|
0 |
All dependencies pass the policy |
1 |
Policy violation (incompatible pairs, denied licenses, or category exceeded) |
2 |
Unknown licenses detected (when fail-on-unknown = true) |
For GitLab, pre-commit, handling unknowns, and the new-dependency workflow, see the CI integration guide.
Configuration
[tool.license-audit]
fail-on-unknown = true
policy = "permissive" # permissive | weak-copyleft | strong-copyleft | network-copyleft
allowed-licenses = ["MIT", "Apache-2.0", "BSD-3-Clause"]
denied-licenses = ["GPL-3.0-only"]
[tool.license-audit.overrides]
some-internal-package = "MIT"
dual-licensed-pkg = "Apache-2.0 OR MIT"
[tool.license-audit.ignored-packages]
pandas-stubs = "Stubs only, not redistributed"
Full reference: user guide -> configuration.
Documentation
Full documentation lives at https://dgeragh.github.io/license-audit:
License
MIT. See LICENSE.
This project bundles data from the OSADL Open Source License Obligations Checklists project, licensed under CC-BY-4.0. See THIRD_PARTY_NOTICES.md for full attribution.
Project details
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 license_audit-0.7.0.tar.gz.
File metadata
- Download URL: license_audit-0.7.0.tar.gz
- Upload date:
- Size: 163.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 |
cc5b60ddaa774614848e11b1d003463dc8239955f1a49d08b70c436521b99895
|
|
| MD5 |
a35813b37ff143af8e2ceeba5bb4b8d5
|
|
| BLAKE2b-256 |
729095f41d8f91d96d1f80a70664d6c44bc74e0696fc40c07753deef0615509e
|
Provenance
The following attestation bundles were made for license_audit-0.7.0.tar.gz:
Publisher:
release.yml on dgeragh/license-audit
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
license_audit-0.7.0.tar.gz -
Subject digest:
cc5b60ddaa774614848e11b1d003463dc8239955f1a49d08b70c436521b99895 - Sigstore transparency entry: 1455320384
- Sigstore integration time:
-
Permalink:
dgeragh/license-audit@229be8284f693b9400edeb02ffbb3cea9a1b6512 -
Branch / Tag:
refs/tags/v0.7.0 - Owner: https://github.com/dgeragh
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@229be8284f693b9400edeb02ffbb3cea9a1b6512 -
Trigger Event:
push
-
Statement type:
File details
Details for the file license_audit-0.7.0-py3-none-any.whl.
File metadata
- Download URL: license_audit-0.7.0-py3-none-any.whl
- Upload date:
- Size: 65.9 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 |
3cf265fcc6c607afb25f5540f5e4aa0be7f31337a063e19326152f31ddedab99
|
|
| MD5 |
8d9b5ea349b9b8d74c067da029c61eef
|
|
| BLAKE2b-256 |
65bdc3a63ccae60fc5c7fe261dea62052bd13abfc1263d2a8a22038c4bf1c864
|
Provenance
The following attestation bundles were made for license_audit-0.7.0-py3-none-any.whl:
Publisher:
release.yml on dgeragh/license-audit
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
license_audit-0.7.0-py3-none-any.whl -
Subject digest:
3cf265fcc6c607afb25f5540f5e4aa0be7f31337a063e19326152f31ddedab99 - Sigstore transparency entry: 1455320492
- Sigstore integration time:
-
Permalink:
dgeragh/license-audit@229be8284f693b9400edeb02ffbb3cea9a1b6512 -
Branch / Tag:
refs/tags/v0.7.0 - Owner: https://github.com/dgeragh
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@229be8284f693b9400edeb02ffbb3cea9a1b6512 -
Trigger Event:
push
-
Statement type: