Русский
Документация
GitLab

GitLab

Используйте OpenCode в задачах и мерж-реквестах GitLab.

OpenCode интегрируется с вашим рабочим процессом GitLab через CI/CD пайплайн или с помощью GitLab Duo.

В обоих случаях OpenCode будет работать на ваших GitLab runners.


GitLab CI

OpenCode работает в обычном пайплайне GitLab. Вы можете встроить его в пайплайн как CI-компонент.

Здесь мы используем созданный сообществом CI/CD компонент для OpenCode — nagyv/gitlab-opencode (opens in a new tab).

Возможности

  • Используйте пользовательскую конфигурацию для каждого задания: настройте OpenCode с пользовательской директорией конфигурации, например ./config/#custom-directory, чтобы включать или отключать функциональность для каждого вызова OpenCode.
  • Минимальная настройка: CI-компонент настраивает OpenCode в фоновом режиме, вам нужно только создать конфигурацию OpenCode и начальный промпт.
  • Гибкость: CI-компонент поддерживает несколько входных параметров для настройки его поведения.

Настройка

  1. Сохраните ваш JSON аутентификации OpenCode как переменные окружения CI типа File в разделе Settings > CI/CD > Variables. Убедитесь, что они отмечены как "Masked and hidden".
  2. Добавьте следующее в ваш файл .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 # The variable name for your OpenCode authentication JSON
      command: optional-custom-command
      message: "Your prompt here"

Для получения дополнительных входных параметров и сценариев использования ознакомьтесь с документацией этого компонента (opens in a new tab).


GitLab Duo

OpenCode интегрируется с вашим рабочим процессом GitLab. Упомяните @opencode в комментарии, и OpenCode выполнит задачи в вашем CI-пайплайне GitLab.

Возможности

  • Сортировка задач: попросите OpenCode изучить задачу и объяснить её вам.
  • Исправление и реализация: попросите OpenCode исправить задачу или реализовать функцию. Он создаст новую ветку и откроет мерж-реквест с изменениями.
  • Безопасность: OpenCode работает на ваших GitLab runners.

Настройка

OpenCode работает в вашем CI/CD пайплайне GitLab, вот что вам понадобится для настройки:

Совет: ознакомьтесь с документацией GitLab (opens in a new tab) для получения актуальных инструкций.

  1. Настройте окружение GitLab
  2. Настройте CI/CD
  3. Получите API-ключ провайдера ИИ-модели
  4. Создайте сервисный аккаунт
  5. Настройте переменные CI/CD
  6. Создайте файл конфигурации flow, вот пример:
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

Подробные инструкции смотрите в документации GitLab CLI agents (opens in a new tab).


Примеры

Вот несколько примеров использования OpenCode в GitLab.

Совет: вы можете настроить использование другой триггерной фразы вместо @opencode.

  • Объяснить задачу

    Добавьте этот комментарий в задачу GitLab. OpenCode прочитает задачу и ответит понятным объяснением.

    @opencode explain this issue
  • Исправить задачу

    В задаче GitLab напишите: OpenCode создаст новую ветку, реализует изменения и откроет мерж-реквест с изменениями.

    @opencode fix this
  • Ревью мерж-реквестов

    Оставьте следующий комментарий к мерж-реквесту GitLab. OpenCode проведёт ревью мерж-реквеста и предоставит обратную связь.

    @opencode review this merge request