Skip to main content

Assistant for reviewing your code

Project description

CodeSpector

CodeSpector is a Python package designed to review code changes for quality and security issues using AI chat agents. It supports different chat agents like Codestral and ChatGPT.

Features

  • Automated code review using AI chat agents.
  • Supports multiple chat agents and models.
  • Generates detailed review reports in markdown format.
  • Configurable via environment variables and command-line options.

Installation

To install the package, use the following command:

pip install codespector
uv add codespector

Usage

Command-Line Interface

You can use the codespector command to start a code review. Below are the available options:

Usage: codespector [OPTIONS]

Options:
  --chat-token TEXT          Chat agent token  [env var: CODESPECTOR_CHAT_TOKEN]
  --chat-model TEXT          Choose the chat model to use  [env var: CODESPECTOR_CHAT_MODEL]
  --chat-agent TEXT          Choose the chat agent to use (codestral, chatgpt, deepseek)
                            or set your own  [env var: CODESPECTOR_CHAT_AGENT]
  -b, --compare-branch TEXT  Select the branch to compare the current one with
  --output-dir TEXT         Select the output directory  [default: codespector]
                            [env var: CODESPECTOR_OUTPUT_DIR]
  --system-content TEXT     Content which used in system field for agent
                            [env var: CODESPECTOR_SYSTEM_CONTENT]
  --prompt-content TEXT     Prompt content which included to review prompt
                            [env var: CODESPECTOR_PROMPT_CONTENT]
  --result-file TEXT        Set file for saving the result
                            [env var: CODESPECTOR_RESULT_FILE]
  --exclude-file-ext LIST   Exclude file extensions from the review
                            [env var: CODESPECTOR_EXCLUDE_FILE_EXT]
  --version                 Show the version and exit.
  --help                    Show this message and exit.

Example

To run a code review, use the following command:

codespector --chat-token YOUR_CHAT_TOKEN --chat-agent codestral --compare-branch develop --result-file result.md --system-content "system content" --prompt-content "prompt content"

Configuration

You can also configure CodeSpector using environment variables. Create a .env file in the root directory of your project with the following content:

CODESPECTOR_CHAT_TOKEN=your_token
CODESPECTOR_OUTPUT_DIR=codespector
CODESPECTOR_SYSTEM_CONTENT="Ты код ревьювер. Отвечай на русском"
CODESPECTOR_PROMPT_CONTENT="Оцени код на безопасноть, соблюдение лучших техник"
CODESPECTOR_RESULT_FILE="result.md"
CODESPECTOR_CHAT_AGENT=codestral
CODESPECTOR_CHAT_MODEL=your_model
CODESPECTOR_EXCLUDE_FILE_EXT=.pyc,.pyo

Makefile Commands

  • lint: Run linting and formatting checks.
  • format: Format the code.
  • fix: Fix linting issues and format the code.
  • test: Run the tests.

License

This project is licensed under the MIT License. See the LICENSE file for more details.

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

codespector-1.0.1.tar.gz (23.2 kB view details)

Uploaded Source

Built Distribution

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

codespector-1.0.1-py3-none-any.whl (8.4 kB view details)

Uploaded Python 3

File details

Details for the file codespector-1.0.1.tar.gz.

File metadata

  • Download URL: codespector-1.0.1.tar.gz
  • Upload date:
  • Size: 23.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for codespector-1.0.1.tar.gz
Algorithm Hash digest
SHA256 30c7c6b645078718acb32391af22db482ca4ed1485530f19fdd467544a125701
MD5 1aa05b4afbf7e7f55b338f61f73fb35e
BLAKE2b-256 f9ba75f7490f3c4a2de0fe917334ce7e27f1f8429a2d93b64a9cf84ae58ada76

See more details on using hashes here.

Provenance

The following attestation bundles were made for codespector-1.0.1.tar.gz:

Publisher: build-publish.yml on Vladimir-Titov/codespector

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file codespector-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: codespector-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 8.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for codespector-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0ff9bd1094b977940a7cbe46769b2f922c1c02bb8639d1484408fdd45032cb59
MD5 a11a002acc1f88dd00b21f3ca67a3bcd
BLAKE2b-256 48ddcb5e6ed420b84eeb6cc3ccd2f90b69ff387109b785647433cb3af5597294

See more details on using hashes here.

Provenance

The following attestation bundles were made for codespector-1.0.1-py3-none-any.whl:

Publisher: build-publish.yml on Vladimir-Titov/codespector

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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