This is small extension to cargo
, to check your dependency tree against the database of
clearlydefined.io.
ClearlyDefined and our parent organization, the Open Source Initiative, are on a mission to help FOSS projects thrive by being, well, clearly defined.
cargo install cargo-clearlydefined
In the project you wan to check, execute the following command:
cargo clearlydefined
This will fetch dependencies metadata, and print out a report of the dependencies that have a score below 80.
To get some command line help, run:
cargo clearlydefined --help
Which should print out:
~~~ cargo-clearlydefined 0.1.0
USAGE: cargo clearlydefined [OPTIONS]
OPTIONS:
-i, --input Override the location of the input file (Cargo.lock
)
-v, --verbose Verbose mode, repeat to increase verbosity
-s, --score
You can set the target score:
cargo clearlydefined --score 50
It is also possible to lower the score to 0
.
By default, only the "failed" dependencies are shown. You can however get a report of all dependencies:
cargo clearlydefined --all
You can exclude dependencies completly from processing:
cargo clearlydefined -x wasi
Or simply ignore it from the target score test:
cargo clearlydefined -n wasi
The default output format is "text", but you have some other options as well:
In order to get a comma separated output:
cargo clearlydefined -o csv
If you choose to show all dependencies, an additional column will be added, that contains the result of the test.
~~~ Name,Version,Declared license,Score hermit-abi,0.1.15,Apache-2.0 AND MIT,52 my-test,0.1.0,,0 winapi-i686-pc-windows-gnu,0.4.0,MIT OR Apache-2.0,37 winapi-x86_64-pc-windows-gnu,0.4.0,MIT OR Apache-2.0,37 ~~~
~~~ Name,Version,Declared license,Score,Check ansiterm,0.12.1,MIT,88,+ atty,0.2.14,MIT,88,+ coloredjson,2.1.0,EPL-2.0,87,+ hermit-abi,0.1.15,Apache-2.0 AND MIT,52,- itoa,0.4.6,Apache-2.0 AND MIT,87,+ libc,0.2.76,Apache-2.0 AND MIT,87,+ my-test,0.1.0,,0,- ryu,1.0.5,Apache-2.0 AND BSL-1.0,80,+ serde,1.0.115,Apache-2.0 AND MIT,87,+ serdejson,1.0.57,Apache-2.0 AND MIT,87,+ winapi,0.3.9,Apache-2.0 AND MIT,87,+ winapi-i686-pc-windows-gnu,0.4.0,MIT OR Apache-2.0,37,- winapi-x8664-pc-windows-gnu,0.4.0,MIT OR Apache-2.0,37,- ~~~
To get a nice markdown result, use:
cargo clearlydefined -o markdown
This will create a markdown table, including a badge, that shows the outcome of the test, if you choose to display all dependencies.
It is also possible to provide the argument --link
, which will always add a link to clearlydefined.io
in the score column.
Using the --link
option.
| Name | Version | Declared license | Score | |------------------------------|---------|--------------------|-------------------------------------------------------------------------------------------------| | hermit-abi | 0.1.15 | Apache-2.0 AND MIT | 52 | | my-test | 0.1.0 | | 0 | | winapi-i686-pc-windows-gnu | 0.4.0 | MIT OR Apache-2.0 | 37 | | winapi-x86_64-pc-windows-gnu | 0.4.0 | MIT OR Apache-2.0 | 37 |
Using the --link
option.
| Name | Version | Declared license | Score |
|------------------------------|---------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ansiterm | 0.12.1 | MIT | |
| atty | 0.2.14 | MIT |
|
| coloredjson | 2.1.0 | EPL-2.0 |
|
| hermit-abi | 0.1.15 | Apache-2.0 AND MIT |
|
| itoa | 0.4.6 | Apache-2.0 AND MIT |
|
| libc | 0.2.76 | Apache-2.0 AND MIT |
|
| my-test | 0.1.0 | |
|
| ryu | 1.0.5 | Apache-2.0 AND BSL-1.0 |
|
| serde | 1.0.115 | Apache-2.0 AND MIT |
|
| serdejson | 1.0.57 | Apache-2.0 AND MIT |
|
| winapi | 0.3.9 | Apache-2.0 AND MIT |
|
| winapi-i686-pc-windows-gnu | 0.4.0 | MIT OR Apache-2.0 |
|
| winapi-x8664-pc-windows-gnu | 0.4.0 | MIT OR Apache-2.0 |
|
And of course, there is plain text as well. The default.
~~~ +------------------------------+---------+--------------------+-------+ | Name | Version | Declared license | Score | +------------------------------+---------+--------------------+-------+ | hermit-abi | 0.1.15 | Apache-2.0 AND MIT | 52 | | my-test | 0.1.0 | | 0 | | winapi-i686-pc-windows-gnu | 0.4.0 | MIT OR Apache-2.0 | 37 | | winapi-x86_64-pc-windows-gnu | 0.4.0 | MIT OR Apache-2.0 | 37 | +------------------------------+---------+--------------------+-------+ ~~~
~~~ +------------------------------+---------+------------------------+-------+ | Name | Version | Declared license | Score | +------------------------------+---------+------------------------+-------+ | ansiterm | 0.12.1 | MIT | 88 ✅ | | atty | 0.2.14 | MIT | 88 ✅ | | coloredjson | 2.1.0 | EPL-2.0 | 87 ✅ | | hermit-abi | 0.1.15 | Apache-2.0 AND MIT | 52 ❌ | | itoa | 0.4.6 | Apache-2.0 AND MIT | 87 ✅ | | libc | 0.2.76 | Apache-2.0 AND MIT | 87 ✅ | | my-test | 0.1.0 | | 0 ❌ | | ryu | 1.0.5 | Apache-2.0 AND BSL-1.0 | 80 ✅ | | serde | 1.0.115 | Apache-2.0 AND MIT | 87 ✅ | | serdejson | 1.0.57 | Apache-2.0 AND MIT | 87 ✅ | | winapi | 0.3.9 | Apache-2.0 AND MIT | 87 ✅ | | winapi-i686-pc-windows-gnu | 0.4.0 | MIT OR Apache-2.0 | 37 ❌ | | winapi-x8664-pc-windows-gnu | 0.4.0 | MIT OR Apache-2.0 | 37 ❌ | +------------------------------+---------+------------------------+-------+ ~~~