Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/guibranco/dotnet-aicommitmessage
🧠🧰 This tool generates AI-powered commit messages via Git hooks, automating meaningful message suggestions from OpenAI and others to improve commit quality and efficiency.
https://github.com/guibranco/dotnet-aicommitmessage
ai ai-powered api dotnet-tool git-commit-messages git-hooks ia openai
Last synced: 4 months ago
JSON representation
🧠🧰 This tool generates AI-powered commit messages via Git hooks, automating meaningful message suggestions from OpenAI and others to improve commit quality and efficiency.
- Host: GitHub
- URL: https://github.com/guibranco/dotnet-aicommitmessage
- Owner: guibranco
- License: mit
- Created: 2024-09-16T19:45:47.000Z (5 months ago)
- Default Branch: main
- Last Pushed: 2024-10-21T07:03:54.000Z (4 months ago)
- Last Synced: 2024-10-21T10:00:40.668Z (4 months ago)
- Topics: ai, ai-powered, api, dotnet-tool, git-commit-messages, git-hooks, ia, openai
- Language: C#
- Homepage: https://guibranco.github.io/dotnet-aicommitmessage/
- Size: 842 KB
- Stars: 1
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# data:image/s3,"s3://crabby-images/72ec6/72ec6171935cee9c6ff29df845a77b14952d6531" alt="GIT Hooks + OpenAI - Generate GIT commit messages from OpenAI"
🧠🧰 This tool generates AI-powered commit messages via Git hooks, automating meaningful message suggestions from OpenAI and others to improve commit quality and efficiency.
[data:image/s3,"s3://crabby-images/b2ae3/b2ae30170e309ce51fd405aea4e6e2585182ea3e" alt="GitHub last commit"](https://wakatime.com/badge/github/guibranco/dotnet-aicommitmessage)
[data:image/s3,"s3://crabby-images/b4004/b4004260cee610f03b6bcf4e74408e95205017e8" alt="GitHub license"](https://wakatime.com/badge/github/guibranco/dotnet-aicommitmessage)
[data:image/s3,"s3://crabby-images/6968a/6968a0a678cc656832ed80018973ca4b9335b854" alt="time tracker"](https://wakatime.com/badge/github/guibranco/dotnet-aicommitmessage)[data:image/s3,"s3://crabby-images/21788/2178882c3f8dff9b1dee2e6ed7cdf6c4c0ce18c7" alt="Build"](https://github.com/guibranco/dotnet-aicommitmessage/actions/workflows/build.yml)
[data:image/s3,"s3://crabby-images/45d03/45d03edad2bd374c9e59e98a0d297bb9a4050259" alt="Continuous Integration"](https://github.com/guibranco/dotnet-aicommitmessage/actions/workflows/ci.yml)
[data:image/s3,"s3://crabby-images/9875e/9875e6ecb0f669acd92f9f0317ce9acff7ed63e5" alt="Infisical secrets check"](https://github.com/guibranco/dotnet-aicommitmessage/actions/workflows/infisical-secrets-check.yml)
[data:image/s3,"s3://crabby-images/9f38b/9f38b585165ae0b3cc194467eec2bac4513718a4" alt="Linter check"](https://github.com/guibranco/dotnet-aicommitmessage/actions/workflows/linter.yml)---
> [!CAUTION]
> This is still in development/beta. It will be **GA** when a major release 1 becomes available.## What this tool does
Generates a commit message based on the `git diff` result using the [OpenAI API](https://platform.openai.com/docs/overview).
---
## Requirements
- [OpenAI API key](https://platform.openai.com/api-keys).
- [.NET 8.0 (or higher) runtime](https://dotnet.microsoft.com/en-us/download/dotnet/8.0).
- [GIT client](https://git-scm.com/downloads).---
## Getting started
[data:image/s3,"s3://crabby-images/8bc95/8bc95ce7e80d161e2deb47e97dd7966edddfbbb1" alt="AICommitMessage NuGet Version"](https://www.nuget.org/packages/AICommitMessage/)
[data:image/s3,"s3://crabby-images/66d67/66d676531d9694ec56fb825b09854e9908a678f9" alt="AICommitMessage NuGet Downloads"](https://www.nuget.org/packages/AICommitMessage/)This repository is available at [NuGet](https://www.nuget.org) under the name [AICommitMessage](https://www.nuget.org/packages/AICommitMessage/).
### Installation
1. Install the tool globally (or per project/repository).
2. Move to the project folder.
3. Install the Git hook on the default `hooks` directory.```ps
dotnet tool install -g AiCommitMessage
cd my-project/
dotnet-aicommitmessage install-hook
git add .
git commit -m ""
```Use `git log -1` to review the last commit details and find the automatically generated commit message.
---
## Commit message pattern
The training model for the AI used is designed using as reference these two guidelines:
- [Conventional Commits v1.0.0](https://www.conventionalcommits.org/en/v1.0.0/).
- [Padrões de Commits](https://github.com/tiagolofi/padroes-de-commits) (in Portuguese).
- [Conventional Commit Messages](https://gist.github.com/qoomon/5dfcdf8eec66a051ecd85625518cfd13).
- [Emoji for Conventional Commits](https://gist.github.com/parmentf/359667bf23e08a1bd8241fbf47ecdef0).
- [conventional-commit-types](https://github.com/pvdlg/conventional-commit-types).---
## Sequence of Execution
Here’s a flow diagram showing the sequence of execution of the `prepare-commit-msg` hook and its integration with `dotnet-aicommitmessage` to generate commit messages using the OpenAI API:
```mermaid
graph TD
A[Git Commit] --> B[prepare-commit-msg Hook Trigger]
B --> C[Invoke dotnet-aicommitmessage Tool]
C --> D[Send Data to OpenAI API]
D --> E[Generate Commit Message]
E --> F[Return Generated Commit Message]
F --> G[Insert Commit Message into Git Commit]
G --> H[Finalize Commit]
```---
## Commands
This tool accepts an argument as the command to execute. Here is a list of available commands:
| Command | Description |
| -------------------------- | --------------------------------------------------------------------------------------------------------------- |
| `install-hook` | Installs GIT hooks in the default `.git/hooks` directory or in the custom directory configured in GIT settings. |
| `generate-message` | Generates a commit message based on the current changes (`git diff` context). |
| `set-settings` | Set the OpenAI settings. |
| `help` | Display information about this program. |
| `version` | Display version information. |
```