mirror of
https://github.com/anomalyco/opencode.git
synced 2026-05-06 00:12:11 +00:00
195 lines
No EOL
7.1 KiB
Text
195 lines
No EOL
7.1 KiB
Text
---
|
|
title: GitLab
|
|
description: Use OpenCode em problemas e solicitações de mesclagem do GitLab.
|
|
---
|
|
|
|
OpenCode se integra ao seu fluxo de trabalho do GitLab através do seu pipeline CI/CD do GitLab ou com o GitLab Duo.
|
|
|
|
Em ambos os casos, o OpenCode será executado em seus runners do GitLab.
|
|
|
|
---
|
|
|
|
## GitLab CI
|
|
|
|
OpenCode funciona em um pipeline regular do GitLab. Você pode integrá-lo a um pipeline como um [componente CI](https://docs.gitlab.com/ee/ci/components/)
|
|
|
|
Aqui estamos usando um componente CI/CD criado pela comunidade para OpenCode — [nagyv/gitlab-opencode](https://gitlab.com/nagyv/gitlab-opencode).
|
|
|
|
---
|
|
|
|
### Recursos
|
|
|
|
- **Use configuração personalizada por trabalho**: Configure o OpenCode com um diretório de configuração personalizado, por exemplo `./config/#custom-directory` para habilitar ou desabilitar funcionalidades por invocação do OpenCode.
|
|
- **Configuração mínima**: O componente CI configura o OpenCode em segundo plano, você só precisa criar a configuração do OpenCode e o prompt inicial.
|
|
- **Flexível**: O componente CI suporta várias entradas para personalizar seu comportamento.
|
|
|
|
---
|
|
|
|
### Configuração
|
|
|
|
1. Armazene seu JSON de autenticação do OpenCode como variáveis de ambiente do tipo File em **Configurações** > **CI/CD** > **Variáveis**. Certifique-se de marcá-las como "Mascaradas e ocultas".
|
|
2. Adicione o seguinte ao seu arquivo `.gitlab-ci.yml`.
|
|
|
|
```yaml title=".gitlab-ci.yml"
|
|
include:
|
|
- component: $CI_SERVER_FQDN/nagyv/gitlab-opencode/opencode@2
|
|
inputs:
|
|
config_dir: ${CI_PROJECT_DIR}/opencode-config
|
|
auth_json: $OPENCODE_AUTH_JSON # O nome da variável para seu JSON de autenticação do OpenCode
|
|
command: optional-custom-command
|
|
message: "Seu prompt aqui"
|
|
```
|
|
|
|
Para mais entradas e casos de uso [consulte a documentação](https://gitlab.com/explore/catalog/nagyv/gitlab-opencode) deste componente.
|
|
|
|
---
|
|
|
|
## GitLab Duo
|
|
|
|
OpenCode se integra ao seu fluxo de trabalho do GitLab.
|
|
Mencione `@opencode` em um comentário, e o OpenCode executará tarefas dentro do seu pipeline CI do GitLab.
|
|
|
|
---
|
|
|
|
### Recursos
|
|
|
|
- **Triagem de problemas**: Peça ao OpenCode para analisar um problema e explicá-lo para você.
|
|
- **Corrigir e implementar**: Peça ao OpenCode para corrigir um problema ou implementar uma funcionalidade.
|
|
Ele criará um novo branch e abrirá uma solicitação de mesclagem com as alterações.
|
|
- **Seguro**: O OpenCode é executado em seus runners do GitLab.
|
|
|
|
---
|
|
|
|
### Configuração
|
|
|
|
O OpenCode é executado em seu pipeline CI/CD do GitLab, aqui está o que você precisará para configurá-lo:
|
|
|
|
:::tip
|
|
Consulte a [**documentação do GitLab**](https://docs.gitlab.com/user/duo_agent_platform/agent_assistant/) para instruções atualizadas.
|
|
:::
|
|
|
|
1. Configure seu ambiente GitLab
|
|
2. Configure CI/CD
|
|
3. Obtenha uma chave de API do provedor de modelo de IA
|
|
4. Crie uma conta de serviço
|
|
5. Configure variáveis de CI/CD
|
|
6. Crie um arquivo de configuração de fluxo, aqui está um exemplo:
|
|
|
|
<details>
|
|
|
|
<summary>Configuração de fluxo</summary>
|
|
|
|
```yaml
|
|
image: node:22-slim
|
|
commands:
|
|
- echo "Instalando opencode"
|
|
- npm install --global opencode-ai
|
|
- echo "Instalando glab"
|
|
- export GITLAB_TOKEN=$GITLAB_TOKEN_OPENCODE
|
|
- apt-get update --quiet && apt-get install --yes curl wget gpg git && rm --recursive --force /var/lib/apt/lists/*
|
|
- curl --silent --show-error --location "https://raw.githubusercontent.com/upciti/wakemeops/main/assets/install_repository" | bash
|
|
- apt-get install --yes glab
|
|
- echo "Configurando glab"
|
|
- echo $GITLAB_HOST
|
|
- echo "Criando configuração de autenticação do OpenCode"
|
|
- mkdir --parents ~/.local/share/opencode
|
|
- |
|
|
cat > ~/.local/share/opencode/auth.json << EOF
|
|
{
|
|
"anthropic": {
|
|
"type": "api",
|
|
"key": "$ANTHROPIC_API_KEY"
|
|
}
|
|
}
|
|
EOF
|
|
- echo "Configurando git"
|
|
- git config --global user.email "opencode@gitlab.com"
|
|
- git config --global user.name "OpenCode"
|
|
- echo "Testando glab"
|
|
- glab issue list
|
|
- echo "Executando OpenCode"
|
|
- |
|
|
opencode run "
|
|
Você é um assistente de IA ajudando com operações do GitLab.
|
|
|
|
Contexto: $AI_FLOW_CONTEXT
|
|
Tarefa: $AI_FLOW_INPUT
|
|
Evento: $AI_FLOW_EVENT
|
|
|
|
Por favor, execute a tarefa solicitada usando as ferramentas disponíveis do GitLab.
|
|
Seja minucioso em sua análise e forneça explicações claras.
|
|
|
|
<important>
|
|
Por favor, use a CLI do glab para acessar dados do GitLab. A CLI do glab já foi autenticada. Você pode executar os comandos correspondentes.
|
|
|
|
Se você for solicitado a resumir um MR ou problema ou a fornecer mais informações, então, por favor, poste uma nota de volta ao MR/Problema para que o usuário possa vê-la.
|
|
Você não precisa fazer commit ou push das alterações, isso será feito automaticamente com base nas alterações de arquivo que você fizer.
|
|
</important>
|
|
"
|
|
- git checkout --branch $CI_WORKLOAD_REF origin/$CI_WORKLOAD_REF
|
|
- echo "Verificando alterações no git e fazendo push se existirem"
|
|
- |
|
|
if ! git diff --quiet || ! git diff --cached --quiet || [ --not --zero "$(git ls-files --others --exclude-standard)" ]; then
|
|
echo "Alterações no Git detectadas, adicionando e fazendo push..."
|
|
git add .
|
|
if git diff --cached --quiet; then
|
|
echo "Nenhuma alteração em estágio para fazer commit"
|
|
else
|
|
echo "Fazendo commit das alterações no branch: $CI_WORKLOAD_REF"
|
|
git commit --message "Alterações do Codex"
|
|
echo "Fazendo push das alterações para $CI_WORKLOAD_REF"
|
|
git push https://gitlab-ci-token:$GITLAB_TOKEN@$GITLAB_HOST/gl-demo-ultimate-dev-ai-epic-17570/test-java-project.git $CI_WORKLOAD_REF
|
|
echo "Alterações enviadas com sucesso"
|
|
fi
|
|
else
|
|
echo "Nenhuma alteração no git detectada, pulando push"
|
|
fi
|
|
variables:
|
|
- ANTHROPIC_API_KEY
|
|
- GITLAB_TOKEN_OPENCODE
|
|
- GITLAB_HOST
|
|
```
|
|
|
|
</details>
|
|
|
|
Você pode consultar a [documentação dos agentes da CLI do GitLab](https://docs.gitlab.com/user/duo_agent_platform/agent_assistant/) para instruções detalhadas.
|
|
|
|
---
|
|
|
|
### Exemplos
|
|
|
|
Aqui estão alguns exemplos de como você pode usar o OpenCode no GitLab.
|
|
|
|
:::tip
|
|
Você pode configurar para usar uma frase de gatilho diferente de `@opencode`.
|
|
:::
|
|
|
|
- **Explicar um problema**
|
|
|
|
Adicione este comentário em um problema do GitLab.
|
|
|
|
```
|
|
@opencode explain this issue
|
|
```
|
|
|
|
O OpenCode lerá o problema e responderá com uma explicação clara.
|
|
|
|
- **Corrigir um problema**
|
|
|
|
Em um problema do GitLab, diga:
|
|
|
|
```
|
|
@opencode fix this
|
|
```
|
|
|
|
O OpenCode criará um novo branch, implementará as alterações e abrirá uma solicitação de mesclagem com as alterações.
|
|
|
|
- **Revisar solicitações de mesclagem**
|
|
|
|
Deixe o seguinte comentário em uma solicitação de mesclagem do GitLab.
|
|
|
|
```
|
|
@opencode review this merge request
|
|
```
|
|
|
|
O OpenCode revisará a solicitação de mesclagem e fornecerá feedback. |