Skip to main content

A modern Python security source code analyzer (SAST) based on distrust.

Project description

Codeaudit

CodeauditLogo

PythonCodeAudit Badge PyPI - Version PyPI - Python Version OpenSSF Best Practices Documentation License PyPI Downloads

Python Code Audit - A modern Python source code analyzer based on distrust.

Python Code Audit is a tool to find security weaknesses in Python code. This static application security testing (SAST) tool has great features to simplify the necessary security tasks and make it fun and easy.

This tool is designed for anyone who uses or creates Python programs and wants to understand and mitigate potential security risks.

This tool is created for:

  • Python Users who want to assess the security risks in the Python code they use.
  • Python Developers: Anyone, from professionals to hobbyists, who wants to deliver secure Python code.
  • Security-Conscious Users: People seeking a simple, fast way to gain insight into potential security vulnerabilities within Python packages or files.

Creating secure software can be challenging. This tool, with its comprehensive documentation, acts as your helpful security colleague, making it easier to identify and address vulnerabilities.

Features

Python Code Audit has the following features:

  • Vulnerability Detection: Identifies security vulnerabilities in Python files, essential for package security research.

  • Complexity & Statistics: Reports security-relevant complexity using a fast, lightweight cyclomatic complexity count via Python's AST.

  • Module Usage & External Vulnerabilities: Detects used modules and reports known vulnerabilities for used external modules.

  • Inline Issue Reporting: Shows potential security issues with line numbers and code snippets.

  • External Egress Detection: Identifies embedded API keys and logic that enables communication with remote services, helping uncover hidden data exfiltration paths.

  • HTML Reports: All output is saved in simple, static HTML reports viewable in any browser.

[!NOTE] Python Code Audit uses the Python's Abstract Syntax Tree (AST) to get robust and reliable result. Using the Python AST makes contextual Vulnerability Detection possible and false positive are minimized.

Installation

pip install -U codeaudit

If you would like to test this security tool without installing it, simply use the WASM version available here.

If you have installed Python Code Audit previously and want to ensure you are using the latest validations and features, simply run this command again. Python Code Audit is frequently updated with new checks.

Usage

After installation you can get an overview of all implemented commands. Just type in your terminal:

codeaudit

This will show all commands:

----------------------------------------------------
 _                    __             _             
|_) \/_|_|_  _ __    /   _  _| _    |_|    _| o _|_
|   /  |_| |(_)| |   \__(_)(_|(/_   | ||_|(_| |  |_
----------------------------------------------------

Python Code Audit - A modern Python security source code analyzer based on distrust.


Commands to evaluate Python source code:
Usage: codeaudit COMMAND <directory|package>  [report.html] 

Depending on the command, you must specify a local directory, a Python file, or a package name hosted on PyPI.org.Reporting: The results are generated as a static HTML report for viewing in a web browser.

Commands:
  overview             Generates an overview report of code complexity and security indicators.
  filescan             Scans Python source code or PyPI packages for security weaknesses.
  modulescan           Generate a report on known vulnerabilities in Python modules and packages.
  checks               Creates an HTML report of all implemented security checks.
  version              Prints the module version. Or use codeaudit [-v] [--v] [-version] or [--version].

Use the Python Code Audit documentation (https://codeaudit.nocomplexity.com) to audit and secure your Python programmes. Explore further essential open-source security tools at https://simplifysecurity.nocomplexity.com/

Example

By running the codeaudit filescan command, detailed security information is determined for a Python file based on more than 80 validations implemented.

The codeaudit filescan command shows all potential security issues that are detected in the source file in a HTML-report.

Per line a the in construct that can cause a security risks is shown, along with the relevant code lines where the issue is detected.

To scan a Python package on PyPI.org on possible security issues, do:

codeaudit filescan <package-name> [reportname.html]

=====================================================================
Codeaudit report file created!
Paste the line below directly into your browser bar:
	file:///home/usainbolt/tmp/codeaudit-report.html

=====================================================================

Example view of filescan report

Contributing

All contributions are welcome! Think of corrections on the documentation, code or more and better tests.

Simple Guidelines:

  • Questions, Feature Requests, Bug Reports please use on the Github Issue Tracker.

Pull Requests are welcome!

When you contribute to Codeaudit, your contributions are made under the same license as the file you are working on.

[!NOTE] This is an open community driven project. Contributors will be mentioned in the documentation.

We adopt the Collective Code Construction Contract(C4) to streamline collaboration.

License

codeaudit is distributed under the terms of the GPL-3.0-or-later license.

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

codeaudit-1.6.4.tar.gz (1.8 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

codeaudit-1.6.4-py3-none-any.whl (83.5 kB view details)

Uploaded Python 3

File details

Details for the file codeaudit-1.6.4.tar.gz.

File metadata

  • Download URL: codeaudit-1.6.4.tar.gz
  • Upload date:
  • Size: 1.8 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.5 cpython/3.14.3 HTTPX/0.28.1

File hashes

Hashes for codeaudit-1.6.4.tar.gz
Algorithm Hash digest
SHA256 c45e0ef0f00f618aeac95c3e3f00bea62560e89f0df9c3ea6cb1a4209d3fa37c
MD5 1d52ee47ab7b02fc5ff6ecf3c05c57a6
BLAKE2b-256 ccc118ff07af767e536302110a86e995a13e6ba422e67f7bf8043f255db515b2

See more details on using hashes here.

File details

Details for the file codeaudit-1.6.4-py3-none-any.whl.

File metadata

  • Download URL: codeaudit-1.6.4-py3-none-any.whl
  • Upload date:
  • Size: 83.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: Hatch/1.16.5 cpython/3.14.3 HTTPX/0.28.1

File hashes

Hashes for codeaudit-1.6.4-py3-none-any.whl
Algorithm Hash digest
SHA256 a70609451ee15b854322fb65c6d1697e4a6ac6f44380edb3cdfe2a9c348e20b7
MD5 a51839bd0f7573c565c6bb88fd6eed4b
BLAKE2b-256 944c371b3a50d5c2c56f091fc4c3b5f8d5d5d968370b80891f5d55034b8a01db

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page