All notable changes to the readme-ai project will be documented in this file.
This release introduces new LLM integrations (Google Vertex AI
and Ollama
), enhances the CLI, and improves the project's documentation. Additionally, this release is bumped to version 0.5.64
to align with the PyPI package version.
- feat: Add CLI options to enhance README.md file customization.
--alignment
: Rename option to control the alignment of the README header text from --align to --alignment.--api
: Select LLM API service to use for generating README content - offline, ollama, openai, vertex.--badge-color
: Add option to change the color of the badge icons in the README header.--badge-style
: Rename option to change the style of the badge icons in the README header from --badges to --badge-style.--image
: option to include a project logo (file path, url, multimodal api) in the README header.--rate-limit
: Add option to control the rate limit for the LLM model.--tree-depth
: Add option to control depth of the generated repository tree structure.--top-p
: Add option to control the top-p value for the LLM model.
- feat: Integrate Ollama for local model support. @eli64s (#92)
- feat: Integrate Google Vertex AI LLM @eli64s (#90)
- chore: Increase
pytest
coverage to over 90 percent. - chore: Integrate
nox
for testing codebase against multiple Python versions.
- Reduce number of non-standard library dependencies @eli64s (#84)
- Setup and deploy mkdocs site via github-pages @eli64s (#87)
- refactor: Reduce complexity of markdown table generator methods. @eli64s (#70)
- enhancement: Add more context to LLM prompts. @eli64s (#69)
- feat: Add CLI option --emojis to change README header prefixes @eli64s (#67)
- fix: #35 Update tokenization logic causing issues for larger codebases @eli64s (#68)
- fix #65: Update dependency parser method for
build.gradle
files @eli64s (#66)
- docs: Update readmeai demo videos. @eli64s (#71)
- Bump urllib3 from 2.0.6 to 2.0.7 @dependabot (#64)
- feat: Add support for three badge icon styles. @eli64s (#62)
- feat: Add README file in German README-de and update other README files (FR, zh-CN).
- Bump urllib3 from 2.0.5 to 2.0.6 @dependabot (#60)
- Add new SVG badge icons that user's can select using the CLI option
--badges
@eli64s (#58) - Refactor
readmeai
package structure to improve organization and readability @eli64s (#58)
- Setup script enhancement @hansipie #42
- Decouple CLI as own directory to improve readability and maintainability @eli64s #56
- Add README files in additional languages [fr, zh-CN] @eli64s #55
- Implement custom directory tree method using pure Python #53
- Removes dependency on the tree command line tool.
- Improves security by removing the subprocess module.
- More details on these risk can be found here
- Add CLI option to run readme-ai offline, generating the same README output excluding the LLM generated text.
- This option is useful for users who want to generate READMEs without an API key.
- The option can be used by passing the
-offline-mode
flag to the CLI.
- Refactor remaining dataclasses in conf.py to Pydantic models.
- Deploy project on Streamlit Community Cloud to provide a web-based interface for generating READMEs.
- Update configuration ignore_files.toml to stop ignoring the following file extensions:
- yaml, toml, txt, lock
- Regenerate all README files in the examples directory to reflect the latest changes to the tool.
- Update README file to enhance project documentation.
- Add Configuration section to provide context for customizing the tool.
- Simplify Getting Started section install and run instructions.
- Update Roadmap section with latest project goals.
- Update file parsing logic in parse.py and preprocess.py for codebases containing the following dependency files (issue #37).
- CMakeLists.txt
- Makefile.am
- configure.ac
- Credit to @mooujarrar for the help in solving this issue!
- Bump gitpython module to version 3.1.36 to address security vulnerability (Dependabot Alert #5 and issue #43).
git.exe
or git
executable.
- Dependabot Alert #3: GitPython untrusted search path on Windows systems leading to arbitrary code execution.
- The previous git clone implementation sets the
env
argument to the path of the git executable in the current working directory. This poses a security risk as the code is susceptible to running arbitrarygit
commands from a malicious repository.git.Repo.clone_from(repo_path, temp_dir, depth=1)
- Updated the
env
argument to explicitly set the absolute path of the git executable. This ensures that the git executable used to clone the repository is the one thats installed in the system path, and not the one located in the current working directory.git.Repo.clone_from(repo_path, temp_dir, depth=1, env=git_exec_path)
- Introduced three methods to help isolate the Git executable discovery and validation logic.
find_git_executable()
: Determines the absolute path of the Git executable.validate_git_executable()
: Validates the found Git executable path.validate_file_permissions()
: Validates the file permissions of the cloned repository.
- For Unix systems, added checks to ensure the permissions of the cloned repository are set to
0o700
. This is a best practice for secure temporary directories and prevents unauthorized users from accessing the directory.
pip install --upgrade readmeai
. Please be mindful of this vulnerability and use caution when cloning repositories from untrusted sources, especially for Windows users.
- Corrected PyPI issue where the readmeai package was not being installed correctly.
- The conf directory was not being included in the PyPI distribution as it was located in the project's root directory.
- The tool now uses the pkg_resources module to access the conf directory from the readmeai package.
- Add .dockerignore file to exclude unnecessary files from the Docker image.
- Missing html closing tags in README tables were causing the GitHub pages site to render incorrectly.
- Added closing tags to fix the issue.
- Additionally, restructured a few sections of the README.
- Refactor Dockerfile to adhere to best practices.
- Package Installation and Cleanup: Clean up cache after installing packages with apt-get to reduce the image size.
- Non-root User Creation: Introduce a non-root user within the container to limit permissions and enhance security.
- Assign a specific user ID and group ID that don't have superuser privileges.
- File Permissions Management: Explicitly manage file permissions to prevent potential security risks when the image operates in varied contexts.
- Publish readme-ai CLI to PyPI under the module name readmeai.
- Refactored the codebase to use Click, migrating from argparse.
- Update directory name from src to readmeai to match PyPI module name.
- Update readmeai modules to use relative imports.
- Update metadata and dependency details in the pyproject.toml file.
- Update README.md documentation.
- Add PyPI package badges at the top of the README.
- Include instructions for downloading and running the readme-ai CLI from PyPI.
- Add helper script update_image.sh to push the latest image to Docker Hub.
- Update Dockerfile commands
- Add line to install the tree command in order to generate the repository tree structure in the README.
- Update installation to use the latest readmeai distribution from PyPI.
- Removed setup.py script from the project root directory.
- Poetry is used for package management via pyproject.toml. Thus, setup.py is no longer needed.
- Add pydantic to validate the user's repository and api key inputs.
- Validation was moved from main.py to conf.py.
- Update README.md file contents.
- Add Changelog section
- Reformat HTML code blocks
- Remove dacite dependency now that pydantic is used for dataclass creation.
- Add CHANGELOG.md to track changes to the project.
- Add new directory examples/video to store mp4 videos to demonstrate the readme-ai tool.
- π§ Remove requirements.txt from the installation and setup scripts.
- π Remove outdated example README.md files from the examples directory.
- Initial release of readme-ai v0.0.1
- Refine the markdown template structure to be more readable.
- Fix various exceptions occurring in builder.py, model.py, and preprocess.py.
- Remove
pandas
dependency from the project.