Tool that just makes your open source project better!
Project description
OSA: OPEN-SOURCE ADVISOR
Built with:
Overview
OSA (Open-Source-Advisor) is a LLM-based tool for improving the quality of scientific open source projects and helping create them from scratch. It automates the generation of README, different levels of documentation, CI/CD scripts, etc. It also generates advices and recommendations for the repository.
OSA is currently under development, so not all features are implemented.
How it works?
Here is a short video:
Table of contents
- Core features
- Installation
- Getting started
- Examples
- Documentation
- Chat with developers: OSA_helpdesk
- Publications about OSA
- Contributing
- License
- Acknowledgments
- Citation
Core features
-
README file generation: Automates the creation of a clear and structured README file for a repository, including projects based on research papers.
-
Documentation generation: Automatically generates docstrings for Python code.
-
Automatic implementation of changes: Clones the repository, creates a branch, commits and pushes changes, and creates a pull request with proposed changes.
-
Various LLMs: Use OSA with an LLM accessible via API (e.g., OpenAI, VseGPT, Ollama), a local server, or try an osa_bot hosted on ITMO servers.
-
Workflow Generator: Automatically generates customizable CI/CD workflows for Python repositories, including unit tests, code formatting, PEP 8 compliance checks, and PyPI publication.
Installation
Install Open-Source-Advisor using one of the following methods:
Using PyPi:
pip install osa_tool
Build from source:
- Clone the Open-Source-Advisor repository:
git clone https://github.com/aimclub/OSA
- Navigate to the project directory:
cd Open-Source-Advisor
- Install the project dependencies:
pip install -r requirements.txt
poetry install
docker build --build-arg GIT_USER_NAME="your-user-name" --build-arg GIT_USER_EMAIL="your-user-email" -f docker/Dockerfile -t {image-name} .
Getting started
Prerequisites
OSA requires Python 3.10 or higher.
The .env file is required to specify the LLM API key (OPENAI_API_KEY or AUTHORIZATION_KEY) and optionally a Git token. The Git token (GIT_TOKEN) may be omitted if you plan to work with a public repository without creating a fork (using the --no-fork option).
Alternatively, instead of GIT_TOKEN, you can use GITHUB_TOKEN, GITLAB_TOKEN, or GITVERSE_TOKEN for GitHub, GitLab, and Gitverse respectively.
When running osa-tool from CLI, you need to set the GIT_TOKEN and API key first:
# Linux / macOS (bash/zsh)
export OPENAI_API_KEY=<your_api_key>
export GIT_TOKEN=<your_git_token>
# Windows (PowerShell)
setx OPENAI_API_KEY "<your_api_key>"
setx GIT_TOKEN "<your_git_token>"
Tokens
| Token name | Description | Mandatory |
|---|---|---|
GIT_TOKEN |
Personal GitHub/GitLab/Gitverse token used to clone private repositories, access metadata, and interact with its API. | Yes |
OPENAI_API_KEY |
API key for accessing OpenAI, vsegpt and openrouter providers | No |
AUTHORIZATION_KEY |
API key for gigachat provider | No |
X-API-Key |
API key for the pepy.tech REST API, used to fetch Python package download statistics | No |
Usage
Run Open-Source-Advisor using the following command:
python -m osa_tool.run -r {repository} [--api {api}] [--base-url {base_url}] [--model {model_name}] [--attachment {article}] [--convert-notebooks {notebook_paths}]
docker run --env-file .env {image-name} -r {repository} [--api {api}] [--base-url {base_url}] [--model {model_name}] [--attachment {article}] [--convert-notebooks {notebook_paths}]
The --attachment option enables you to choose a README template for a repository based on an article. You can provide either a link to a PDF file of the article or a path to a local PDF file after the --attachment option. If you are using Docker, ensure that you upload the PDF file to the OSA folder before building the image, then, specify the path as /app/OSA/... or just use volume mounting to access the file.
The --generate-workflows option is intended to create customizable CI/CD pipelines for Python repositories. For detailed documentation, see the Workflow Generator README.
Configuration
| Flag | Description | Default |
|---|---|---|
-r, --repository |
URL of the GitHub/GitLab/Gitverse repository (Mandatory) | |
-b, --branch |
Branch name of the repository | Default branch |
-o, --output |
Path to the output directory | Current working directory |
--api |
LLM API service provider | itmo |
--base-url |
URL of the provider compatible with API OpenAI | https://api.openai.com/v1 |
--model |
Specific LLM model to use | gpt-3.5-turbo |
--top_p |
Nucleus sampling probability | None |
--temperature |
Sampling temperature to use for the LLM output (0 = deterministic, 1 = creative). | None |
--max_tokens |
Maximum number of tokens the model can generate in a single response | None |
--attachment |
Path to a local PDF or .docx file, or a URL to a PDF resource | None |
-m, --mode |
Operation mode for repository processing: basic, auto (default), or advanced. |
auto |
--delete-dir |
Enable deleting the downloaded repository after processing | disabled |
--no-fork |
Avoid create fork for target repository | False |
--no-pull-request |
Avoid create pull request for target repository | False |
To learn how to work with the interactive CLI and view descriptions of all available keys, visit the CLI usage guide.
Examples
Examples of generated README files are available in examples.
URL of the GitHub/GitLab/Gitverse repository, LLM API service provider (optional) and Specific LLM model to use (optional) are required to use the generator.
Supported LLM providers are available as part of the ProtoLLM ecosystem. See the connectors directory for the full list.
Local ITMO model:
python -m osa_tool.run -r https://github.com/aimclub/OSA --base-url [ITMO_MODEL_URL]
For this API provider itmo model url must be specified in dotenv (ITMO_MODEL_URL=) or in the --base-url argument.
OpenAI:
python -m osa_tool.run -r https://github.com/aimclub/OSA --api openai
VseGPT:
python -m osa_tool.run -r https://github.com/aimclub/OSA --api openai --base-url https://api.vsegpt.ru/v1 --model openai/gpt-3.5-turbo
Openrouter:
python -m osa_tool.run -r https://github.com/aimclub/OSA --api openai --base-url https://openrouter.ai/api/v1 --model qwen/qwen3-30b-a3b-instruct-2507
Ollama:
python -m osa_tool.run -r https://github.com/aimclub/OSA --api ollama --base-url http://[YOUR_OLLAMA_IP]:11434 --model gemma3:27b
Documentation
Detailed description of OSA API is available here.
Chat with developers: OSA_helpdesk
In our Telegram chat OSA_helpdesk you can ask questions about working with OSA and find the latest news about the project.
Publications about OSA
In English:
In Russian:
Contributing
- Report Issues: Submit bugs found or log feature requests for the Open-Source-Advisor project.
License
This project is protected under the BSD 3-Clause "New" or "Revised" License. For more details, refer to the LICENSE file.
Acknowledgments
The project is supported as ITMO University Research Project in AI Initiative (RPAII).
OSA is tested by the members of ITMO OpenSource community. Useful content from community is available in Open-source-ops
Also, we thank Readme-ai for their code that we used as a foundation for our own version of README generator.
Citation
If you use this software, please cite it as below.
Simple format
Nikitin N. et al. An LLM-Powered Tool for Enhancing Scientific Open-Source Repositories // Championing Open-source DEvelopment in ML Workshop@ ICML25.
BibTeX format
@inproceedings{nikitinllm,
title={An LLM-Powered Tool for Enhancing Scientific Open-Source Repositories},
author={Nikitin, Nikolay and Getmanov, Andrey and Popov, Zakhar and
Ulyanova Ekaterina and Aksenkin, Yaroslav and
Sokolov, Ilya and Boukhanovsky, Alexander},
booktitle={Championing Open-source DEvelopment in ML Workshop@ ICML25}
}
Project details
Release history Release notifications | RSS feed
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file osa_tool-0.2.4.0.tar.gz.
File metadata
- Download URL: osa_tool-0.2.4.0.tar.gz
- Upload date:
- Size: 1.3 MB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d13a2df9f9ed34aaba4d46367082f24c6450dbdf4e3250d9214f0dcb0ec1e67b
|
|
| MD5 |
667dde11cc72299e12d2037e9227b574
|
|
| BLAKE2b-256 |
723be48ffabde05bb51c36b77450d5635e49ed3935c7b7176316f7f5fe24dcde
|
Provenance
The following attestation bundles were made for osa_tool-0.2.4.0.tar.gz:
Publisher:
release.yml on aimclub/OSA
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
osa_tool-0.2.4.0.tar.gz -
Subject digest:
d13a2df9f9ed34aaba4d46367082f24c6450dbdf4e3250d9214f0dcb0ec1e67b - Sigstore transparency entry: 709782464
- Sigstore integration time:
-
Permalink:
aimclub/OSA@bd1ad66980cebed326142ca945c6413d71a4c18d -
Branch / Tag:
refs/tags/v0.2.4.0 - Owner: https://github.com/aimclub
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@bd1ad66980cebed326142ca945c6413d71a4c18d -
Trigger Event:
push
-
Statement type:
File details
Details for the file osa_tool-0.2.4.0-py3-none-any.whl.
File metadata
- Download URL: osa_tool-0.2.4.0-py3-none-any.whl
- Upload date:
- Size: 1.3 MB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b65569ea0315980503e6e8c6c365e593c0f06bf52be4a07b01642e4be33f21d5
|
|
| MD5 |
cfc85edc0361ec64df4212c16a3894e8
|
|
| BLAKE2b-256 |
67326b2ee633717861df26c8d2ec7f050ca4c77b084007902e2a49ab70e9bc10
|
Provenance
The following attestation bundles were made for osa_tool-0.2.4.0-py3-none-any.whl:
Publisher:
release.yml on aimclub/OSA
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
osa_tool-0.2.4.0-py3-none-any.whl -
Subject digest:
b65569ea0315980503e6e8c6c365e593c0f06bf52be4a07b01642e4be33f21d5 - Sigstore transparency entry: 709782467
- Sigstore integration time:
-
Permalink:
aimclub/OSA@bd1ad66980cebed326142ca945c6413d71a4c18d -
Branch / Tag:
refs/tags/v0.2.4.0 - Owner: https://github.com/aimclub
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
release.yml@bd1ad66980cebed326142ca945c6413d71a4c18d -
Trigger Event:
push
-
Statement type: