8 releases

0.1.7 Dec 24, 2024
0.1.6 Oct 15, 2023
0.1.5 Jun 29, 2023
0.1.3 May 22, 2023

#664 in Command line utilities

Download history 7/week @ 2024-09-23 28/week @ 2024-12-02 36/week @ 2024-12-09 9/week @ 2024-12-16 159/week @ 2024-12-23 20/week @ 2024-12-30 21/week @ 2025-01-06

211 downloads per month

MIT license

1MB
1.5K SLoC

🐍 Pyscan

CI Liscense PyPI GitHub issues Top Language

A dependency vulnerability scanner for your python projects, straight from the terminal.
  • can be used within large projects. (see benchmarks)
  • automatically finds dependencies either from configuration files or within source code.
  • support for poetry,hatch,filt,pdm and can be integrated into existing build processes.
  • hasn't been battle-hardened yet. PRs and issue makers welcome.

🕊️ Install

pip install pyscan-rs

look out for the "-rs" part or

cargo install pyscan

🐇 Usage

Go to your python source directory (or wherever you keep your requirements.txt/pyproject.toml) and run:

> pyscan

or

> pyscan -d path/to/src

Pyscan will find any dependencies added through poetry, hatch, filt, pdm, etc. Here's the order of precedence for a source/config file:
  • requirements.txt
  • pyproject.toml
  • your source code (.py)

Pyscan will use your pip to find unknown versions, otherwise pypi.org for the latest version. Still, it is recommended to version-ize your requirements and use proper pep-508 syntax.

Building

pyscan requires a rust version of < v1.70, and might be unstable on previous releases. There's an overview of the codebase at architecture. Grateful for all the contributions so far.

🦀 Note

pyscan doesn't make sure your code is safe from everything. Use all resources available to you like safety Dependabot, pip-audit, trivy and the likes.

🐰 Todo

As of October 15, 2023:

  • Gather time to work on it (incredible task as a high schooler college freshman)
  • Persistent state representation of a project's security.
  • Graphical analysis of dependencies and their dependencies, and so on.
  • Better display, search, filter of vulns
  • Finish the "big" update (All of the above is a part of PR #17)

🐹 Donate

While not coding, I am a broke high school student with nothing else to do. I appreciate all the help I can get.

Dependencies

~15–29MB
~399K SLoC