Log License
Project description
Log License
A tool for helping developers staying compliant within their software projects. The tool crawls dependencies and logs their licenses, allowing to document and restrict certain licenses within a software project.
DISCLAIMER: There is no guarentee that all sublicenses or licenses will be identified and reported. For highest ensurance, use lock files to also catch sub-dependencies. However, this only looks within the given package manager, meaning C libraries and alike will not be reported here.
Features
- Report and save log of licenses included in project
- Check coverage of packages supported accepted licenses
- Supporting pre-commits with coverage thresholds and allowing manual validation of unknown license types
Supported dependency files
Though the tool supports multiple file types, it is highly recommended to use lock files or do a ´pip freeze > requirements.txt´ in order to ensure all sub-dependencies are also evaluated for their license.
- poetry.lock
- pyproject.toml (traditional and poetry)
- requirements.txt (--develop adds search for requirements_dev.txt)
Supported package managers
- pypi
Installation
You can install Log License via pip from PyPI:
$ pip install loglicense
or using Poetry
$ poetry add loglicense
Quick example
Please see the Command-line Reference for details.
$ loglicense report path_to/poetry.lock
Example output:
| Name | License |
|:-------------------|:-----------------------------------|
| click | BSD-3-Clause |
| colorama | BSD |
| importlib-metadata | Apache Software License |
| pathlib | MIT License |
| tabulate | MIT |
| toml | MIT |
| typer | MIT License |
| typing-extensions | Python Software Foundation License |
| zipp | MIT License |
Alternatively you can let it search the executed directory for any supported file
$ loglicense report
Features to implement
- Support npmjs package manager (and package.json/package-lock.json)
- Support Pipfile, Pipfile.lock, conda.yaml, pip freeze
Contributing
Contributions are very welcome. To learn more, see the Contributor Guide.
License
Distributed under the terms of the Apache 2.0 license, Log License is free and open source software.
Issues
If you encounter any problems, please file an issue along with a detailed description.
Credits
This project was generated from @cjolowicz's Hypermodern Python Cookiecutter template.
This project is greatly inspired by dep-license created by Abdulelah Bin Mahfoodh.
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
File details
Details for the file loglicense-0.1.8.tar.gz
.
File metadata
- Download URL: loglicense-0.1.8.tar.gz
- Upload date:
- Size: 13.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 51715b106dcffe729bb9c3ba9614e2b336d2a543a871166bc3e520611e4d0704 |
|
MD5 | 01b046fd09c408e1e75d32157c8d6bfd |
|
BLAKE2b-256 | e8e3e8a582b96a03242d9274b6cfe227fa04d63d27060f8b072b8ac533589929 |
File details
Details for the file loglicense-0.1.8-py3-none-any.whl
.
File metadata
- Download URL: loglicense-0.1.8-py3-none-any.whl
- Upload date:
- Size: 12.8 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.9.18
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | cd5748bd1673ad7fa6be3d72f71b38eae33c6ad9b70e372a786195718ebb1d29 |
|
MD5 | f8d9ff2af527fb0d8e412d2854685040 |
|
BLAKE2b-256 | 0837e189dbbc88358ba2897002253b28a422812a2e6828822704890558ece5fc |