Skip to content

Gitai é uma ferramenta de automação Python para gerenciamento de commits no Git. Analisa alterações em projetos de várias linguagens, gera mensagens de commit detalhadas seguindo o padrão Conventional Commits e automatiza o processo de commit e push.

License

Notifications You must be signed in to change notification settings

leandrosilvaferreira/gitai

Repository files navigation

Gitai - Conventional Commits automatizados no Git com IA

Release Notes GitHub star chart GitHub fork

Gitai é um projeto Python que serve como uma ferramenta de automação para gerenciamento de commits no Git. Ele é projetado para analisar projetos escritos em várias linguagens de programação, incluindo Node.js, Python, Java, Go e PHP.

A aplicação analisa as alterações feitas em um projeto, identifica a linguagem de programação usada e, com base nisso, gera uma mensagem de commit detalhada seguindo o padrão Conventional Commits. Este padrão é amplamente adotado para tornar as mensagens de commit mais descritivas e úteis.

Além disso, Gitai automatiza o processo de commit, adicionando todas as alterações ao índice do Git, realizando o commit com a mensagem gerada e, opcionalmente, fazendo push das alterações para o repositório remoto.

Para a geração da mensagem de commit, é possível escolher entre os modelos de linguagem avançados da OpenAI ou Groq.

O projeto também utiliza as bibliotecas openai, groq, python-dotenv e pyinstaller para criar um executável que inclui as dependências do ambiente virtual e que lê as variáveis de ambiente de um arquivo .env na mesma pasta que o executável.

💻 Screenshot

Gitai

Gitai

🎥 Tutorial em Vídeo

Clique na imagem abaixo para assistir ao tutorial em vídeo sobre o Gitai:

AUTOMATIZAÇÃO DE COMMITS DO GIT COM IA: GITAI (OPEN SOURCE E GRATUITO)

⚡ Instalando a Aplicação no Mac

Depois de gerar o arquivo .pkg, você pode seguir os passos abaixo para instalar a aplicação no seu Mac:

  1. Navegue até o local onde o arquivo .pkg foi salvo.
  2. Dê um duplo clique no arquivo .pkg para iniciar o instalador.
  3. Siga as instruções na tela para instalar a aplicação. Você pode precisar inserir sua senha de administrador.
  4. Após a instalação, a aplicação estará disponível no seu diretório de Aplicativos.

Lembre-se de que, após a instalação, você deve configurar o arquivo .env com as variáveis de ambiente necessárias para a aplicação funcionar corretamente.

🤖 Escolhendo o Modelo de IA

O Gitai oferece suporte a dois provedores de IA para gerar mensagens de commit: OpenAI e Groq.

Cada um tem suas características, custos e limites de utilização.

Ambos os provedores são altamente capazes, mas sua escolha pode depender de suas necessidades específicas e do orçamento disponível.

Se você precisa de uma grande capacidade de processamento e pode arcar com os custos, OpenAI é uma excelente opção. Por outro lado, se você prefere um serviço sem custo e pode gerenciar dentro dos limites de utilização, Groq é uma alternativa viável e eficiente.

Abaixo estão as informações detalhadas sobre cada provedor para ajudá-lo a escolher o melhor para suas necessidades.

OpenAI

OpenAI é um serviço pago que oferece modelos de linguagem avançados.

O modelo mais eficiente disponível é o gpt-4o, que tem uma janela de contexto de 128K tokens.

  • Custo:
    • $5.00 por 1M tokens para Input
    • $15.00 por 1M tokens para Output
  • Site: OpenAI

Groq

Groq é um serviço gratuito, mas com limites de utilização.

O modelo recomendado é o mixtral-8x7b-32768, que oferece uma janela de contexto de 32,768 tokens.

  • Limites de Utilização:
    • Requests por Minuto: 30
    • Requests por Dia: 14,400
    • Tokens por Minuto: 5,000
  • Site: Groq

🌱 Configurando o .env

Antes de executar o aplicativo, você precisa configurar o arquivo .env na pasta dist ou na pasta onde o GITAI foi instalado. Este arquivo contém as variáveis de ambiente que o aplicativo precisa para funcionar corretamente.

Você pode escolher entre usar o provedor OpenAI ou Groq.

Abra o arquivo .env em um editor de texto e preencha as variáveis de ambiente.

Exemplo de configuração para OpenAI

PROVIDER=openai
API_KEY=your_openai_api_key
MODEL=gpt-4o
LANGUAGE=en

Exemplo de configuração para Groq

PROVIDER=groq
API_KEY=your_groq_api_key
MODEL=mixtral-8x7b-32768
LANGUAGE=en

💻 Adicionando o Aplicativo ao Terminal

Para tornar o aplicativo disponível no terminal, você precisa adicionar o diretório do aplicativo ao PATH do sistema. O PATH é uma variável de ambiente que especifica uma lista de diretórios onde os comandos executáveis são procurados.

Você pode adicionar o diretório do aplicativo ao PATH adicionando a seguinte linha ao arquivo .bash_profile ou .zshrc (dependendo do shell que você está usando) no diretório inicial do usuário:

export PATH="$PATH:/Applications/Gitai/"

Depois de adicionar essa linha, você precisa executar o comando source para carregar as alterações:

source ~/.bash_profile  # Se você estiver usando bash
source ~/.zshrc  # Se você estiver usando zsh

Agora, você deve ser capaz de executar o aplicativo a partir do terminal.

🚀 Usando o Gitai

Depois de instalar e configurar o Gitai, você pode começar a usá-lo para gerar mensagens de commit automaticamente para o seu projeto.

Para usar o Gitai, você precisa abrir o terminal na raiz do seu projeto. Isso é importante porque o Gitai precisa ter acesso aos arquivos do seu projeto para analisar as alterações e gerar as mensagens de commit.

Uma vez que o terminal esteja aberto na raiz do seu projeto, você pode executar o Gitai com o seguinte comando:

gitai <caminho_do_projeto> '<mensagem_genérica>'

Substitua <caminho_do_projeto> pelo caminho do diretório do seu projeto e <mensagem_genérica> por uma descrição básica da mudança que você fez no projeto.

Se você estiver com o terminal aberto na raiz do seu projeto e a mudança foi para adicionar uma nova funcionalidade, você pode simplesmente digitar:

gitai . 'Adicionada nova funcionalidade'

Se você deseja analisar somente uma pasta específica ou um projeto em outra pasta, por exemplo, se você fez uma alteração no seu projeto localizado em /Users/username/MeuProjeto, você pode executar o Gitai com o seguinte comando:

gitai /Users/username/MeuProjeto 'Adicionada nova funcionalidade'

Para gerar o commit e fazer push de forma automática, você pode adicionar a flag --push ao comando:

gitai . 'Adicionada nova funcionalidade' --push

👨‍💻 Desenvolvimento

Pré-requisitos

  • Python 3.7 ou superior
  • pip (gerenciador de pacotes do Python)
  • git

Configuração do Ambiente

  1. Clone o repositório para a sua máquina local usando git clone.
git clone <url-do-repositorio>
  1. Navegue até o diretório do projeto.
cd <nome-do-projeto>
  1. Instale as dependências do projeto.
pip install -r requirements.txt

Gerando o executável

Para executar o build do projeto, execute o script build.sh na raiz do projeto.

./build.sh

Este script irá gerar um executável do script Python usando o PyInstaller chamado gitai e copiará o arquivo .env.example para a pasta dist.

Caso você queira gerar um executável para uma plataforma específica, você pode usar os seguintes comandos:

Gerando o Instalador para Windows

Para gerar um instalador para Windows, você precisa usar a ferramenta Inno Setup.

Instalando o Inno Setup

  1. Acesse o site oficial do Inno Setup em http://www.jrsoftware.org/isinfo.php
  2. Clique no link "Download" na página.
  3. Baixe a versão mais recente do Inno Setup.
  4. Após o download do arquivo .exe, abra-o.
  5. Siga as instruções na tela para instalar o Inno Setup.
  6. Após a instalação, o Inno Setup deve estar disponível no seu computador.
  7. Abra o Inno Setup e clique em "File" > "New" para criar um novo script de instalação.
  8. Preencha os detalhes do seu projeto, como nome, versão e descrição.
  9. Adicione os arquivos necessários ao instalador, incluindo o executável gerado pelo PyInstaller e o arquivo .env de exemplo.
  10. Configure as opções de instalação, como o diretório de instalação e os atalhos.
  11. Clique em "Build" para gerar o instalador.
  12. Após a compilação, você terá um arquivo .exe que pode ser distribuído e usado para instalar o seu aplicativo no Windows.
  13. Execute o instalador no computador de destino para instalar o aplicativo.
  14. Após a instalação, o aplicativo estará disponível no menu Iniciar e no diretório de instalação.

Gerando o Instalador para Linux

Para gerar um instalador para Linux, você precisa usar a ferramenta Makeself.

Instalando o Makeself

  1. Acesse o site oficial do Makeself em https://makeself.io/
  2. Clique no link "Download" na página.
  3. Baixe a versão mais recente do Makeself.
  4. Após o download do arquivo .run, abra-o.
  5. Siga as instruções na tela para instalar o Makeself.
  6. Após a instalação, o Makeself deve estar disponível no seu computador.
  7. Abra o terminal e navegue até o diretório onde o executável gerado pelo PyInstaller está localizado.
  8. Execute o seguinte comando para criar o instalador:
makeself <diretório_de_origem> <nome_do_instalador> "<descrição_do_instalador>" <comando_de_instalação>

Substitua <diretório_de_origem> pelo diretório onde o executável gerado pelo PyInstaller está localizado, <nome_do_instalador> pelo nome do arquivo do instalador, <descrição_do_instalador> por uma descrição do instalador e <comando_de_instalação> por um comando de instalação.

Por exemplo:

makeself dist/ GitaiInstaller.run "Instalador do Gitai" "./gitai"

Isso irá criar um arquivo .run que pode ser distribuído e usado para instalar o seu aplicativo no Linux.

Gerando o Instalador para macOS

Para gerar um instalador para macOS, você precisa usar a ferramenta Packages.

Instalando o Packages

  1. Acesse o site oficial do Packages em http://s.sudre.free.fr/Software/Packages/about.html
  2. Clique no link "Download" na página.
  3. Após o download do arquivo .dmg, abra-o.
  4. Arraste o ícone do Packages para a pasta de Aplicativos.

Agora, o Packages deve estar instalado e pronto para uso no seu Mac.

Criando o Instalador

  1. Abra o Packages e clique em "New Project".
  2. Selecione "Distribution" e clique em "Next".
  3. Dê um nome ao seu projeto e escolha onde salvá-lo.
  4. No painel esquerdo, clique em "Project" e preencha os detalhes do seu projeto.
  5. No painel esquerdo, clique em "Settings" e configure as opções de instalação.
  6. No painel esquerdo, clique em "Scripts" e adicione um script de pós-instalação que instala as bibliotecas Python necessárias.
  7. No painel esquerdo, clique em "Payload" e adicione o executável e o arquivo .env de exemplo ao diretório de instalação.
  8. No menu "Build", selecione "Build".

Isso irá criar um arquivo .pkg que instala o seu aplicativo.

O Gitai irá analisar as alterações feitas no seu projeto, identificar a linguagem de programação usada e, com base nisso, gerar uma mensagem de commit detalhada seguindo o padrão Conventional Commits. Em seguida, ele irá adicionar todas as alterações ao índice do Git e realizar o commit com a mensagem gerada.

📝 TODO

  • Gerar release para Mac
  • Gerar release para Windows
  • Gerar release para Linux
  • Atualizar a documentação para incluir instruções de instalação para Windows e Linux
  • Adicionar possibilidade de utilizar a API do GROQ para gerar mensagens de commit
  • Adicionar binário executável automaticamente no PATH
  • Adicionar suporte para mais linguagens de programação
  • Traduzir a documentação para Inglês
  • Traduzir prompts para Inglês
  • Adicionar testes automatizados

🙌 Contribuindo

Agradecemos o seu interesse em contribuir para o Gitai! Aqui estão algumas diretrizes que podem ajudá-lo no processo:

  1. Fork o Repositório: Faça um fork do repositório Gitai para a sua conta do GitHub. Isso significa que você terá uma cópia do repositório em sua própria conta, permitindo que você faça alterações sem afetar o projeto original.

  2. Clone o Repositório: Clone o repositório para a sua máquina local para que você possa fazer alterações.

  3. Crie uma Branch: Crie uma nova branch em seu fork para fazer suas alterações. Isso ajuda a separar suas alterações de outras que possam estar acontecendo simultaneamente.

  4. Faça suas Alterações: Faça as alterações que você acha que melhorariam o projeto. Isso pode ser a adição de uma nova funcionalidade, a correção de um bug ou a melhoria da documentação.

  5. Teste suas Alterações: Certifique-se de que suas alterações não quebram nada e que o código ainda funciona como esperado.

  6. Envie um Pull Request: Envie um pull request para o repositório original propondo suas alterações. Certifique-se de dar uma descrição detalhada de suas alterações para que os mantenedores do projeto possam entender o que você fez e por quê.

📄 Código de Conduta

Pedimos que todos os contribuintes sigam nosso código de conduta. Respeito mútuo é fundamental para um ambiente de colaboração saudável. Por favor, seja profissional e respeitoso com os outros contribuintes.

🙋 Suporte

Se você tiver alguma dúvida ou problema, por favor, abra uma issue. Faremos o nosso melhor para ajudá-lo.

📨 Contato

Se você quiser entrar em contato com os mantenedores do projeto, por favor, envie um e-mail para: leandro@notyped.com

Obrigado por seu interesse em nosso projeto. Estamos ansiosos para ver suas contribuições!

🤓 Autor

Leandro Silva Ferreira

🙌 Contribuidores

Obrigado a estes incríveis contribuidores

Star History Chart

📄 Licença

Este projeto está licenciado sob a licença MIT. Isso significa que você é livre para copiar, modificar, mesclar, publicar, distribuir, sublicenciar e/ou vender cópias do software, desde que forneça o devido crédito ao autor original e reproduza a licença em todas as cópias ou partes substanciais do software.

Para mais detalhes, veja o arquivo LICENSE no repositório.

About

Gitai é uma ferramenta de automação Python para gerenciamento de commits no Git. Analisa alterações em projetos de várias linguagens, gera mensagens de commit detalhadas seguindo o padrão Conventional Commits e automatiza o processo de commit e push.

Resources

License

Stars

Watchers

Forks

Packages

No packages published