Saltearse al contenido

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-directory para 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

  1. 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”.

  2. Agregue lo siguiente a su archivo .gitlab-ci.yml.

    .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 # El nombre de variable para su JSON de autenticacion de OpenCode
    command: optional-custom-command
    message: "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:

  1. Configure su entorno de GitLab

  2. Configure CI/CD

  3. Obtenga una clave API de proveedor de modelo de IA

  4. Crear una cuenta de servicio

  5. Configure variables de CI/CD

  6. Crear un archivo de configuracion de flujo, aqui hay un ejemplo:

    Configuracion de flujo
    image: node:22-slim
    commands:
    - 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.email "[email protected]"
    - 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_CONTEXT
    Task: $AI_FLOW_INPUT
    Event: $AI_FLOW_EVENT
    Please 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)" ]; then
    echo "Git changes detected, adding and pushing..."
    git add .
    if git diff --cached --quiet; then
    echo "No staged changes to commit"
    else
    echo "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_REF
    echo "Changes successfully pushed"
    fi
    else
    echo "No git changes detected, skipping push"
    fi
    variables:
    - 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 issue

    OpenCode leera la issue y respondra con una explicacion clara.

  • Corregir una issue

    En una issue de GitLab, diga:

    @opencode fix this

    OpenCode 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 request

    OpenCode revisara la solicitud de fusion y proporcionara comentarios.