GitLab
Use OpenCode en issues y solicitudes de fusion de GitLab.
OpenCode se integra con su flujo de trabajo de GitLab a traves de su canalizacion CI/CD de GitLab o con GitLab Duo.
En ambos casos, OpenCode se ejecutara en sus ejecutores de GitLab.
GitLab CI
OpenCode funciona en una canalizacion de GitLab regular. Puede construirlo en una canalizacion como un componente CI
Aquí estamos usando un componente CI/CD creado por la comunidad para OpenCode - nagyv/gitlab-opencode.
Caracteristicas
- Usar configuracion personalizada por trabajo: Configurar OpenCode con un directorio de configuracion personalizado, por ejemplo
./config/#custom-directorypara habilitar o deshabilitar funcionalidad por invocacion de OpenCode. - Configuracion minima: El componente CI configura OpenCode en segundo plano, solo necesita crear la configuracion de OpenCode y el prompt inicial.
- Flexible: El componente CI admite varias entradas para personalizar su comportamiento
Configuracion
-
Almacene su JSON de autenticacion de OpenCode como variables de entorno de CI de tipo Archivo bajo Configuracion > CI/CD > Variables. Asegurese de marcarlas como “Enmascarado y oculto”.
-
Agregue lo siguiente a su archivo
.gitlab-ci.yml..gitlab-ci.yml include:- component: $CI_SERVER_FQDN/nagyv/gitlab-opencode/opencode@2inputs:config_dir: ${CI_PROJECT_DIR}/opencode-configauth_json: $OPENCODE_AUTH_JSON # El nombre de variable para su JSON de autenticacion de OpenCodecommand: optional-custom-commandmessage: "Your prompt here"
Para mas entradas y casos de uso consulte la documentacion para este componente.
GitLab Duo
OpenCode se integra con su flujo de trabajo de GitLab.
Mencione @opencode en un comentario, y OpenCode ejecutara tareas dentro de su canalizacion CI de GitLab.
Caracteristicas
- Triage de issues: Pida a OpenCode que investigue una issue y se la explique.
- Corregir e implementar: Pida a OpenCode que corrija una issue o implemente una caracteristica. Trabajara para crear una nueva rama y enviara una solicitud de fusion con los cambios.
- Seguro: OpenCode se ejecuta en sus ejecutores de GitLab.
Configuracion
OpenCode se ejecuta en su canalizacion CI/CD de GitLab, aqui es lo que necesitara para configurarlo:
-
Configure su entorno de GitLab
-
Configure CI/CD
-
Obtenga una clave API de proveedor de modelo de IA
-
Crear una cuenta de servicio
-
Configure variables de CI/CD
-
Crear un archivo de configuracion de flujo, aqui hay un ejemplo:
Configuracion de flujo
image: node:22-slimcommands:- echo "Installing opencode"- npm install --global opencode-ai- echo "Installing 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 "Configuring glab"- echo $GITLAB_HOST- echo "Creating OpenCode auth configuration"- mkdir --parents ~/.local/share/opencode- |cat > ~/.local/share/opencode/auth.json << EOF{"anthropic": {"type": "api","key": "$ANTHROPIC_API_KEY"}}EOF- echo "Configuring git"- git config --global user.name "OpenCode"- echo "Testing glab"- glab issue list- echo "Running OpenCode"- |opencode run "You are an AI assistant helping with GitLab operations.Context: $AI_FLOW_CONTEXTTask: $AI_FLOW_INPUTEvent: $AI_FLOW_EVENTPlease execute the requested task using the available GitLab tools.Be thorough in your analysis and provide clear explanations.<important>Please use the glab CLI to access data from GitLab. The glab CLI has already been authenticated. You can run the corresponding commands.If you are asked to summarize an MR or issue or asked to provide more information then please post back a note to the MR/Issue so that the user can see it.You don't need to commit or push up changes, those will be done automatically based on the file changes you make.</important>"- git checkout --branch $CI_WORKLOAD_REF origin/$CI_WORKLOAD_REF- echo "Checking for git changes and pushing if any exist"- |if ! git diff --quiet || ! git diff --cached --quiet || [ --not --zero "$(git ls-files --others --exclude-standard)" ]; thenecho "Git changes detected, adding and pushing..."git add .if git diff --cached --quiet; thenecho "No staged changes to commit"elseecho "Committing changes to branch: $CI_WORKLOAD_REF"git commit --message "Codex changes"echo "Pushing changes up to $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_REFecho "Changes successfully pushed"fielseecho "No git changes detected, skipping push"fivariables:- ANTHROPIC_API_KEY- GITLAB_TOKEN_OPENCODE- GITLAB_HOST
Puede consultar la documentacion de agentes CLI de GitLab para obtener instrucciones detalladas.
Ejemplos
Aquí hay algunos ejemplos de como puede usar OpenCode en GitLab.
-
Explicar una issue
Agregue este comentario en una issue de GitLab.
@opencode explain this issueOpenCode leera la issue y respondra con una explicacion clara.
-
Corregir una issue
En una issue de GitLab, diga:
@opencode fix thisOpenCode creara una nueva rama, implementara los cambios y abrira una solicitud de fusion con los cambios.
-
Revisar solicitudes de fusion
Deje el siguiente comentario en una solicitud de fusion de GitLab.
@opencode review this merge requestOpenCode revisara la solicitud de fusion y proporcionara comentarios.